home *** CD-ROM | disk | FTP | other *** search
MacBinary | 1993-06-12 | 27.4 KB | [ TEXT/KAHL]
open in: MacOS 8.1
extracted
|
Win98
extracted
|
DOS
extracted
view JSON data
|
view as text
This file was processed as: MacBinary
(archive/macBinary ).
You can browse this item here: tiffinfo.c
Confidence Program Detection Match Type Support
66%
dexvert
Compact Compressed (Unix) (archive/compact)
ext
Supported
10%
dexvert
MacBinary (archive/macBinary)
fallback
Supported
1%
dexvert
Text File (text/txt)
fallback
Supported
100%
file
MacBinary II, Sat Jun 12 13:16:04 1993, modified Sat Jun 12 13:16:04 1993, creator Think C, type ASCII, 27241 bytes "tiffinfo.c" , at 0x6ae9 632 bytes resource
default (weak)
99%
file
data
default
74%
TrID
Macintosh plain text (MacBinary)
default
25%
TrID
MacBinary 2
default (weak)
100%
siegfried
fmt/1762 MacBinary (II)
default
100%
lsar
MacBinary
default
id metadata key value macFileType [ TEXT] macFileCreator [ KAHL]
hex view +--------+-------------------------+-------------------------+--------+--------+ |00000000| 00 0a 74 69 66 66 69 6e | 66 6f 2e 63 00 00 00 00 |..tiffin|fo.c....| |00000010| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........| |00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........| |00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........| |00000040| 00 54 45 58 54 4b 41 48 | 4c 00 00 00 00 00 00 00 |.TEXTKAH|L.......| |00000050| 00 00 00 00 00 6a 69 00 | 00 02 78 a8 3f bf d4 a8 |.....ji.|..x.?...| |00000060| 3f bf d4 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |?.......|........| |00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 d4 79 00 00 |........|.....y..| |00000080| 2f 2a 0d 20 2a 20 54 68 | 69 73 20 73 6f 66 74 77 |/*. * Th|is softw| |00000090| 61 72 65 20 69 73 20 63 | 6f 70 79 72 69 67 68 74 |are is c|opyright| |000000a0| 20 31 39 39 32 20 62 79 | 20 52 6f 62 65 72 74 20 | 1992 by| Robert | |000000b0| 4d 6f 72 72 69 73 2e 0d | 20 2a 20 59 6f 75 20 6d |Morris..| * You m| |000000c0| 61 79 20 66 72 65 65 6c | 79 20 72 65 64 69 73 74 |ay freel|y redist| |000000d0| 72 69 62 75 74 65 20 74 | 68 69 73 20 73 6f 66 74 |ribute t|his soft| |000000e0| 77 61 72 65 20 61 73 20 | 73 68 61 72 65 77 61 72 |ware as |sharewar| |000000f0| 65 0d 20 2a 20 69 66 20 | 79 6f 75 20 64 6f 20 73 |e. * if |you do s| |00000100| 6f 20 69 6e 20 74 68 65 | 20 73 61 6d 65 20 66 6f |o in the| same fo| |00000110| 72 6d 20 61 73 20 79 6f | 75 20 67 6f 74 20 69 74 |rm as yo|u got it| |00000120| 2e 20 49 66 20 79 6f 75 | 20 66 69 6e 64 0d 20 2a |. If you| find. *| |00000130| 20 74 68 69 73 20 73 6f | 66 74 77 61 72 65 20 75 | this so|ftware u| |00000140| 73 65 66 75 6c 2c 20 70 | 6c 65 61 73 65 20 73 65 |seful, p|lease se| |00000150| 6e 64 20 24 31 32 20 74 | 6f 3a 0d 20 2a 20 20 20 |nd $12 t|o:. * | |00000160| 52 6f 62 65 72 74 20 4d | 6f 72 72 69 73 0d 20 2a |Robert M|orris. *| |00000170| 20 20 20 50 2e 4f 2e 20 | 42 6f 78 20 31 30 34 34 | P.O. |Box 1044| |00000180| 0d 20 2a 20 20 20 48 61 | 72 76 61 72 64 20 53 71 |. * Ha|rvard Sq| |00000190| 75 61 72 65 20 53 74 61 | 74 69 6f 6e 0d 20 2a 20 |uare Sta|tion. * | |000001a0| 20 20 43 61 6d 62 72 69 | 64 67 65 2c 20 4d 41 20 | Cambri|dge, MA | |000001b0| 30 32 32 33 38 0d 20 2a | 20 20 20 65 63 6f 67 6e |02238. *| ecogn| |000001c0| 6f 6d 65 40 61 6f 6c 2e | 63 6f 6d 0d 20 2a 20 49 |ome@aol.|com. * I| |000001d0| 66 20 79 6f 75 20 69 6e | 63 6f 72 70 6f 72 61 74 |f you in|corporat| |000001e0| 65 20 61 6e 79 20 6f 66 | 20 74 68 69 73 20 73 6f |e any of| this so| |000001f0| 66 74 77 61 72 65 20 69 | 6e 20 61 6e 79 20 6b 69 |ftware i|n any ki| |00000200| 6e 64 20 6f 66 0d 20 2a | 20 63 6f 6d 6d 65 72 63 |nd of. *| commerc| |00000210| 69 61 6c 20 70 72 6f 64 | 75 63 74 2c 20 70 6c 65 |ial prod|uct, ple| |00000220| 61 73 65 20 73 65 6e 64 | 20 24 32 20 70 65 72 20 |ase send| $2 per | |00000230| 63 6f 70 79 20 64 69 73 | 74 72 69 62 75 74 65 64 |copy dis|tributed| |00000240| 0d 20 2a 20 74 6f 20 74 | 68 65 20 61 62 6f 76 65 |. * to t|he above| |00000250| 20 61 64 64 72 65 73 73 | 2e 0d 20 2a 2f 0d 20 0d | address|.. */. .| |00000260| 2f 2a 0d 20 2a 20 6d 61 | 6e 69 70 75 6c 61 74 65 |/*. * ma|nipulate| |00000270| 20 54 49 46 46 20 66 69 | 6c 65 73 2e 0d 20 2a 2f | TIFF fi|les.. */| |00000280| 0d 23 69 6e 63 6c 75 64 | 65 20 22 74 69 66 66 69 |.#includ|e "tiffi| |00000290| 6e 66 6f 2e 68 22 0d 23 | 69 6e 63 6c 75 64 65 20 |nfo.h".#|include | |000002a0| 22 73 74 72 69 6e 67 2e | 68 22 0d 0d 23 69 66 64 |"string.|h"..#ifd| |000002b0| 65 66 20 54 49 46 46 5f | 50 52 49 4e 54 46 53 0d |ef TIFF_|PRINTFS.| |000002c0| 23 69 6e 63 6c 75 64 65 | 20 3c 73 74 64 69 6f 2e |#include| <stdio.| |000002d0| 68 3e 0d 23 65 6e 64 69 | 66 0d 0d 76 6f 69 64 20 |h>.#endi|f..void | |000002e0| 54 49 46 46 45 72 72 6f | 72 28 54 49 46 46 50 74 |TIFFErro|r(TIFFPt| |000002f0| 72 2c 20 4f 53 45 72 72 | 2c 20 53 74 72 69 6e 67 |r, OSErr|, String| |00000300| 50 74 72 29 3b 0d 6c 6f | 6e 67 20 74 74 6f 68 73 |Ptr);.lo|ng ttohs| |00000310| 28 54 49 46 46 50 74 72 | 2c 20 73 68 6f 72 74 29 |(TIFFPtr|, short)| |00000320| 3b 0d 6c 6f 6e 67 20 74 | 74 6f 68 6c 28 54 49 46 |;.long t|tohl(TIF| |00000330| 46 50 74 72 2c 20 6c 6f | 6e 67 29 3b 0d 4f 53 45 |FPtr, lo|ng);.OSE| |00000340| 72 72 20 74 69 66 66 5f | 72 65 61 64 28 54 49 46 |rr tiff_|read(TIF| |00000350| 46 50 74 72 2c 20 75 6e | 73 69 67 6e 65 64 20 6c |FPtr, un|signed l| |00000360| 6f 6e 67 2c 20 76 6f 69 | 64 20 2a 2c 20 6c 6f 6e |ong, voi|d *, lon| |00000370| 67 29 3b 0d 4f 53 45 72 | 72 20 53 63 61 6e 54 49 |g);.OSEr|r ScanTI| |00000380| 46 46 44 69 72 65 63 74 | 6f 72 79 28 54 49 46 46 |FFDirect|ory(TIFF| |00000390| 50 74 72 29 3b 0d 4f 53 | 45 72 72 20 52 65 61 64 |Ptr);.OS|Err Read| |000003a0| 54 49 46 46 45 6e 74 72 | 79 28 54 49 46 46 50 74 |TIFFEntr|y(TIFFPt| |000003b0| 72 2c 20 6c 6f 6e 67 20 | 6f 66 66 73 65 74 2c 20 |r, long |offset, | |000003c0| 73 74 72 75 63 74 20 54 | 49 46 46 45 6e 74 72 79 |struct T|IFFEntry| |000003d0| 20 2a 29 3b 0d 6c 6f 6e | 67 20 50 61 72 73 65 53 | *);.lon|g ParseS| |000003e0| 63 61 6c 61 72 28 54 49 | 46 46 50 74 72 2c 20 73 |calar(TI|FFPtr, s| |000003f0| 74 72 75 63 74 20 54 49 | 46 46 45 6e 74 72 79 20 |truct TI|FFEntry | |00000400| 2a 29 3b 0d 6c 6f 6e 67 | 20 2a 50 61 72 73 65 41 |*);.long| *ParseA| |00000410| 72 72 61 79 28 54 49 46 | 46 50 74 72 2c 20 73 74 |rray(TIF|FPtr, st| |00000420| 72 75 63 74 20 54 49 46 | 46 45 6e 74 72 79 20 2a |ruct TIF|FEntry *| |00000430| 29 3b 0d 43 54 61 62 48 | 61 6e 64 6c 65 20 54 72 |);.CTabH|andle Tr| |00000440| 61 6e 73 6c 61 74 65 43 | 6f 6c 6f 72 4d 61 70 28 |anslateC|olorMap(| |00000450| 6c 6f 6e 67 20 2a 63 6f | 6c 6f 72 4d 61 70 2c 20 |long *co|lorMap, | |00000460| 69 6e 74 20 6e 63 6f 6c | 6f 72 73 29 3b 0d 43 54 |int ncol|ors);.CT| |00000470| 61 62 48 61 6e 64 6c 65 | 20 4d 61 6b 65 47 72 61 |abHandle| MakeGra| |00000480| 79 54 61 62 6c 65 28 69 | 6e 74 20 64 65 70 74 68 |yTable(i|nt depth| |00000490| 2c 20 69 6e 74 20 7a 65 | 72 6f 49 73 57 68 69 74 |, int ze|roIsWhit| |000004a0| 65 29 3b 0d 50 74 72 20 | 54 68 72 65 65 54 6f 46 |e);.Ptr |ThreeToF| |000004b0| 6f 75 72 28 50 74 72 20 | 69 6e 2c 20 6c 6f 6e 67 |our(Ptr |in, long| |000004c0| 20 6e 50 69 78 65 6c 73 | 29 3b 0d 6c 6f 6e 67 20 | nPixels|);.long | |000004d0| 52 6f 77 42 79 74 65 73 | 28 54 49 46 46 50 74 72 |RowBytes|(TIFFPtr| |000004e0| 29 3b 0d 76 6f 69 64 20 | 43 6f 70 79 50 4d 53 74 |);.void |CopyPMSt| |000004f0| 72 69 70 28 50 69 78 4d | 61 70 48 61 6e 64 6c 65 |rip(PixM|apHandle| |00000500| 20 70 6d 2c 20 52 65 63 | 74 20 73 72 2c 20 52 65 | pm, Rec|t sr, Re| |00000510| 63 74 20 64 72 2c 20 69 | 6e 74 20 64 69 74 68 65 |ct dr, i|nt dithe| |00000520| 72 29 3b 0d 76 6f 69 64 | 20 43 6f 70 79 42 4d 53 |r);.void| CopyBMS| |00000530| 74 72 69 70 28 42 69 74 | 4d 61 70 20 2a 2c 20 52 |trip(Bit|Map *, R| |00000540| 65 63 74 20 73 72 2c 20 | 52 65 63 74 20 64 72 2c |ect sr, |Rect dr,| |00000550| 20 69 6e 74 20 69 6e 76 | 29 3b 0d 76 6f 69 64 20 | int inv|);.void | |00000560| 55 6e 44 69 66 66 65 72 | 65 6e 63 65 28 50 74 72 |UnDiffer|ence(Ptr| |00000570| 20 70 2c 20 6c 6f 6e 67 | 20 72 6f 77 62 79 74 65 | p, long| rowbyte| |00000580| 73 2c 20 6c 6f 6e 67 20 | 6e 72 6f 77 73 2c 20 6c |s, long |nrows, l| |00000590| 6f 6e 67 20 73 70 61 6e | 29 3b 0d 0d 2f 2a 0d 20 |ong span|);../*. | |000005a0| 2a 20 53 63 61 6e 20 61 | 20 54 49 46 46 20 66 69 |* Scan a| TIFF fi| |000005b0| 6c 65 27 73 20 66 69 65 | 6c 64 73 20 74 6f 20 66 |le's fie|lds to f| |000005c0| 65 72 72 65 74 20 6f 75 | 74 20 69 6e 74 65 72 65 |erret ou|t intere| |000005d0| 73 74 69 6e 67 20 69 6e | 66 6f 72 6d 61 74 69 6f |sting in|formatio| |000005e0| 6e 2e 0d 20 2a 20 52 65 | 74 75 72 6e 73 20 61 20 |n.. * Re|turns a | |000005f0| 54 49 46 46 50 74 72 20 | 77 68 65 74 68 65 72 20 |TIFFPtr |whether | |00000600| 69 74 20 73 75 63 63 65 | 65 64 65 64 20 6f 72 20 |it succe|eded or | |00000610| 66 61 69 6c 65 64 3b 20 | 74 68 65 20 63 61 6c 6c |failed; |the call| |00000620| 65 72 20 6d 75 73 74 0d | 20 2a 20 63 61 6c 6c 20 |er must.| * call | |00000630| 47 65 74 54 49 46 46 45 | 72 72 6f 72 28 29 20 74 |GetTIFFE|rror() t| |00000640| 6f 20 64 69 73 74 69 6e | 67 75 69 73 68 2e 0d 20 |o distin|guish.. | |00000650| 2a 2f 0d 54 49 46 46 50 | 74 72 0d 53 63 61 6e 54 |*/.TIFFP|tr.ScanT| |00000660| 49 46 46 28 69 6e 74 20 | 72 65 66 29 0d 7b 0d 09 |IFF(int |ref).{..| |00000670| 73 74 72 75 63 74 20 54 | 49 46 46 48 65 61 64 65 |struct T|IFFHeade| |00000680| 72 20 68 65 61 64 65 72 | 3b 0d 09 54 49 46 46 50 |r header|;..TIFFP| |00000690| 74 72 20 74 69 3b 0d 09 | 0d 09 74 69 20 3d 20 28 |tr ti;..|..ti = (| |000006a0| 54 49 46 46 50 74 72 29 | 20 4e 65 77 50 74 72 28 |TIFFPtr)| NewPtr(| |000006b0| 73 69 7a 65 6f 66 28 2a | 74 69 29 29 3b 0d 09 69 |sizeof(*|ti));..i| |000006c0| 66 28 74 69 20 3d 3d 20 | 30 29 0d 09 09 72 65 74 |f(ti == |0)...ret| |000006d0| 75 72 6e 28 30 29 3b 0d | 09 6d 65 6d 73 65 74 28 |urn(0);.|.memset(| |000006e0| 74 69 2c 20 30 2c 20 73 | 69 7a 65 6f 66 28 2a 74 |ti, 0, s|izeof(*t| |000006f0| 69 29 29 3b 20 2f 2a 20 | 63 6c 65 61 72 20 74 68 |i)); /* |clear th| |00000700| 65 20 72 65 63 6f 72 64 | 20 2a 2f 0d 09 0d 09 74 |e record| */....t| |00000710| 69 2d 3e 72 65 66 20 3d | 20 72 65 66 3b 0d 09 0d |i->ref =| ref;...| |00000720| 09 69 66 28 74 69 66 66 | 5f 72 65 61 64 28 74 69 |.if(tiff|_read(ti| |00000730| 2c 20 30 4c 2c 20 26 68 | 65 61 64 65 72 2c 20 73 |, 0L, &h|eader, s| |00000740| 69 7a 65 6f 66 28 68 65 | 61 64 65 72 29 29 20 21 |izeof(he|ader)) !| |00000750| 3d 20 30 29 0d 09 09 72 | 65 74 75 72 6e 28 74 69 |= 0)...r|eturn(ti| |00000760| 29 3b 0d 09 0d 09 74 69 | 2d 3e 62 79 74 65 4f 72 |);....ti|->byteOr| |00000770| 64 65 72 20 3d 20 68 65 | 61 64 65 72 2e 62 79 74 |der = he|ader.byt| |00000780| 65 4f 72 64 65 72 3b 0d | 09 69 66 28 28 74 69 2d |eOrder;.|.if((ti-| |00000790| 3e 62 79 74 65 4f 72 64 | 65 72 20 21 3d 20 42 69 |>byteOrd|er != Bi| |000007a0| 67 45 6e 64 69 61 6e 20 | 26 26 20 74 69 2d 3e 62 |gEndian |&& ti->b| |000007b0| 79 74 65 4f 72 64 65 72 | 20 21 3d 20 4c 69 74 74 |yteOrder| != Litt| |000007c0| 6c 65 45 6e 64 69 61 6e | 29 20 7c 7c 0d 09 20 20 |leEndian|) ||.. | |000007d0| 20 74 74 6f 68 73 28 74 | 69 2c 20 68 65 61 64 65 | ttohs(t|i, heade| |000007e0| 72 2e 76 65 72 73 69 6f | 6e 4e 75 6d 62 65 72 29 |r.versio|nNumber)| |000007f0| 20 21 3d 20 34 32 29 7b | 0d 09 20 20 20 09 54 49 | != 42){|.. .TI| |00000800| 46 46 45 72 72 6f 72 28 | 74 69 2c 20 2d 31 2c 20 |FFError(|ti, -1, | |00000810| 22 5c 70 4e 6f 74 20 61 | 20 54 49 46 46 20 66 69 |"\pNot a| TIFF fi| |00000820| 6c 65 2e 22 29 3b 0d 09 | 09 72 65 74 75 72 6e 28 |le.");..|.return(| |00000830| 74 69 29 3b 0d 09 7d 0d | 09 0d 09 74 69 2d 3e 6f |ti);..}.|...ti->o| |00000840| 66 66 73 65 74 20 3d 20 | 74 74 6f 68 6c 28 74 69 |ffset = |ttohl(ti| |00000850| 2c 20 68 65 61 64 65 72 | 2e 6f 66 66 73 65 74 29 |, header|.offset)| |00000860| 3b 0d 09 53 63 61 6e 54 | 49 46 46 44 69 72 65 63 |;..ScanT|IFFDirec| |00000870| 74 6f 72 79 28 74 69 29 | 3b 0d 09 0d 09 72 65 74 |tory(ti)|;....ret| |00000880| 75 72 6e 28 74 69 29 3b | 0d 7d 0d 0d 76 6f 69 64 |urn(ti);|.}..void| |00000890| 0d 44 69 73 70 6f 73 65 | 54 49 46 46 28 54 49 46 |.Dispose|TIFF(TIF| |000008a0| 46 50 74 72 20 74 69 29 | 0d 7b 0d 09 69 66 28 74 |FPtr ti)|.{..if(t| |000008b0| 69 29 7b 0d 09 09 69 66 | 28 74 69 2d 3e 62 69 74 |i){...if|(ti->bit| |000008c0| 73 50 65 72 53 61 6d 70 | 6c 65 29 0d 09 09 09 44 |sPerSamp|le)....D| |000008d0| 69 73 70 6f 73 50 74 72 | 28 74 69 2d 3e 62 69 74 |isposPtr|(ti->bit| |000008e0| 73 50 65 72 53 61 6d 70 | 6c 65 29 3b 0d 09 09 74 |sPerSamp|le);...t| |000008f0| 69 2d 3e 62 69 74 73 50 | 65 72 53 61 6d 70 6c 65 |i->bitsP|erSample| |00000900| 20 3d 20 30 3b 0d 09 09 | 69 66 28 74 69 2d 3e 63 | = 0;...|if(ti->c| |00000910| 6f 6c 6f 72 4d 61 70 29 | 0d 09 09 09 44 69 73 70 |olorMap)|....Disp| |00000920| 6f 73 43 54 61 62 6c 65 | 28 74 69 2d 3e 63 6f 6c |osCTable|(ti->col| |00000930| 6f 72 4d 61 70 29 3b 0d | 09 09 74 69 2d 3e 63 6f |orMap);.|..ti->co| |00000940| 6c 6f 72 4d 61 70 20 3d | 20 30 3b 0d 09 09 69 66 |lorMap =| 0;...if| |00000950| 28 74 69 2d 3e 73 74 72 | 69 70 4f 66 66 73 65 74 |(ti->str|ipOffset| |00000960| 73 29 0d 09 09 09 44 69 | 73 70 6f 73 50 74 72 28 |s)....Di|sposPtr(| |00000970| 74 69 2d 3e 73 74 72 69 | 70 4f 66 66 73 65 74 73 |ti->stri|pOffsets| |00000980| 29 3b 0d 09 09 74 69 2d | 3e 73 74 72 69 70 4f 66 |);...ti-|>stripOf| |00000990| 66 73 65 74 73 20 3d 20 | 30 3b 0d 09 09 69 66 28 |fsets = |0;...if(| |000009a0| 74 69 2d 3e 73 74 72 69 | 70 42 79 74 65 43 6f 75 |ti->stri|pByteCou| |000009b0| 6e 74 73 29 0d 09 09 09 | 44 69 73 70 6f 73 50 74 |nts)....|DisposPt| |000009c0| 72 28 74 69 2d 3e 73 74 | 72 69 70 42 79 74 65 43 |r(ti->st|ripByteC| |000009d0| 6f 75 6e 74 73 29 3b 0d | 09 09 74 69 2d 3e 73 74 |ounts);.|..ti->st| |000009e0| 72 69 70 42 79 74 65 43 | 6f 75 6e 74 73 20 3d 20 |ripByteC|ounts = | |000009f0| 30 3b 0d 09 09 44 69 73 | 70 6f 73 50 74 72 28 74 |0;...Dis|posPtr(t| |00000a00| 69 29 3b 0d 09 7d 0d 7d | 0d 0d 4f 53 45 72 72 0d |i);..}.}|..OSErr.| |00000a10| 53 63 61 6e 54 49 46 46 | 44 69 72 65 63 74 6f 72 |ScanTIFF|Director| |00000a20| 79 28 54 49 46 46 50 74 | 72 20 74 69 29 0d 7b 0d |y(TIFFPt|r ti).{.| |00000a30| 09 75 6e 73 69 67 6e 65 | 64 20 73 68 6f 72 74 20 |.unsigne|d short | |00000a40| 6e 65 6e 74 72 69 65 73 | 2c 20 65 6e 74 72 79 6e |nentries|, entryn| |00000a50| 6f 3b 0d 09 73 74 72 75 | 63 74 20 54 49 46 46 45 |o;..stru|ct TIFFE| |00000a60| 6e 74 72 79 20 65 6e 74 | 72 79 3b 0d 09 6c 6f 6e |ntry ent|ry;..lon| |00000a70| 67 20 6e 65 78 74 6f 66 | 66 73 65 74 2c 20 6e 2c |g nextof|fset, n,| |00000a80| 20 69 2c 20 6f 66 66 73 | 65 74 2c 20 2a 63 6f 6c | i, offs|et, *col| |00000a90| 6f 72 4d 61 70 20 3d 20 | 30 3b 0d 09 4f 53 45 72 |orMap = |0;..OSEr| |00000aa0| 72 20 65 72 72 3b 0d 09 | 0d 09 6f 66 66 73 65 74 |r err;..|..offset| |00000ab0| 20 3d 20 74 69 2d 3e 6f | 66 66 73 65 74 3b 0d 09 | = ti->o|ffset;..| |00000ac0| 74 69 2d 3e 65 72 72 20 | 3d 20 30 3b 0d 09 0d 09 |ti->err |= 0;....| |00000ad0| 2f 2a 20 61 73 73 69 67 | 6e 20 64 65 66 61 75 6c |/* assig|n defaul| |00000ae0| 74 20 76 61 6c 75 65 73 | 20 2a 2f 0d 09 74 69 2d |t values| */..ti-| |00000af0| 3e 62 69 74 73 50 65 72 | 53 61 6d 70 6c 65 20 3d |>bitsPer|Sample =| |00000b00| 20 28 6c 6f 6e 67 20 2a | 29 20 4e 65 77 50 74 72 | (long *|) NewPtr| |00000b10| 28 73 69 7a 65 6f 66 28 | 6c 6f 6e 67 29 29 3b 0d |(sizeof(|long));.| |00000b20| 09 69 66 28 74 69 2d 3e | 62 69 74 73 50 65 72 53 |.if(ti->|bitsPerS| |00000b30| 61 6d 70 6c 65 20 3d 3d | 20 30 29 7b 0d 09 09 54 |ample ==| 0){...T| |00000b40| 49 46 46 45 72 72 6f 72 | 28 74 69 2c 20 65 72 72 |IFFError|(ti, err| |00000b50| 20 3d 20 4d 65 6d 45 72 | 72 6f 72 28 29 2c 20 22 | = MemEr|ror(), "| |00000b60| 5c 70 4f 75 74 20 6f 66 | 20 6d 65 6d 6f 72 79 22 |\pOut of| memory"| |00000b70| 29 3b 0d 09 09 72 65 74 | 75 72 6e 28 65 72 72 29 |);...ret|urn(err)| |00000b80| 3b 0d 09 7d 0d 09 74 69 | 2d 3e 62 69 74 73 50 65 |;..}..ti|->bitsPe| |00000b90| 72 53 61 6d 70 6c 65 5b | 30 5d 20 3d 20 31 3b 0d |rSample[|0] = 1;.| |00000ba0| 09 74 69 2d 3e 63 6f 6c | 6f 72 4d 61 70 20 3d 20 |.ti->col|orMap = | |00000bb0| 30 3b 0d 09 74 69 2d 3e | 63 6f 6d 70 72 65 73 73 |0;..ti->|compress| |00000bc0| 69 6f 6e 20 3d 20 4e 6f | 43 6f 6d 70 72 65 73 73 |ion = No|Compress| |00000bd0| 69 6f 6e 3b 0d 09 74 69 | 2d 3e 70 72 65 64 69 63 |ion;..ti|->predic| |00000be0| 74 6f 72 20 3d 20 4e 6f | 50 72 65 64 69 63 74 6f |tor = No|Predicto| |00000bf0| 72 3b 0d 09 74 69 2d 3e | 69 6d 61 67 65 4c 65 6e |r;..ti->|imageLen| |00000c00| 67 74 68 20 3d 20 2d 31 | 3b 0d 09 74 69 2d 3e 69 |gth = -1|;..ti->i| |00000c10| 6d 61 67 65 57 69 64 74 | 68 20 3d 20 2d 31 3b 0d |mageWidt|h = -1;.| |00000c20| 09 74 69 2d 3e 70 68 6f | 74 6f 6d 65 74 72 69 63 |.ti->pho|tometric| |00000c30| 49 6e 74 65 72 70 72 65 | 74 61 74 69 6f 6e 20 3d |Interpre|tation =| |00000c40| 20 2d 31 3b 0d 09 74 69 | 2d 3e 70 6c 61 6e 61 72 | -1;..ti|->planar| |00000c50| 43 6f 6e 66 69 67 75 72 | 61 74 69 6f 6e 20 3d 20 |Configur|ation = | |00000c60| 50 43 43 6f 6e 74 69 67 | 75 6f 75 73 3b 0d 09 74 |PCContig|uous;..t| |00000c70| 69 2d 3e 72 6f 77 73 50 | 65 72 53 74 72 69 70 20 |i->rowsP|erStrip | |00000c80| 3d 20 30 78 37 66 66 66 | 66 66 66 66 3b 0d 09 74 |= 0x7fff|ffff;..t| |00000c90| 69 2d 3e 73 61 6d 70 6c | 65 73 50 65 72 50 69 78 |i->sampl|esPerPix| |00000ca0| 65 6c 20 3d 20 31 3b 0d | 09 74 69 2d 3e 73 74 72 |el = 1;.|.ti->str| |00000cb0| 69 70 42 79 74 65 43 6f | 75 6e 74 73 20 3d 20 30 |ipByteCo|unts = 0| |00000cc0| 3b 0d 09 74 69 2d 3e 73 | 74 72 69 70 4f 66 66 73 |;..ti->s|tripOffs| |00000cd0| 65 74 73 20 3d 20 30 3b | 0d 09 74 69 2d 3e 74 36 |ets = 0;|..ti->t6| |00000ce0| 4f 70 74 69 6f 6e 73 20 | 3d 20 30 3b 0d 09 74 69 |Options |= 0;..ti| |00000cf0| 2d 3e 66 69 6c 6c 4f 72 | 64 65 72 20 3d 20 31 3b |->fillOr|der = 1;| |00000d00| 0d 09 0d 09 69 66 28 28 | 65 72 72 20 3d 20 74 69 |....if((|err = ti| |00000d10| 66 66 5f 72 65 61 64 28 | 74 69 2c 20 74 69 2d 3e |ff_read(|ti, ti->| |00000d20| 6f 66 66 73 65 74 2c 20 | 26 6e 65 6e 74 72 69 65 |offset, |&nentrie| |00000d30| 73 2c 20 73 69 7a 65 6f | 66 28 6e 65 6e 74 72 69 |s, sizeo|f(nentri| |00000d40| 65 73 29 29 29 20 21 3d | 20 30 29 0d 09 09 72 65 |es))) !=| 0)...re| |00000d50| 74 75 72 6e 28 65 72 72 | 29 3b 0d 09 6f 66 66 73 |turn(err|);..offs| |00000d60| 65 74 20 2b 3d 20 73 69 | 7a 65 6f 66 28 6e 65 6e |et += si|zeof(nen| |00000d70| 74 72 69 65 73 29 3b 0d | 09 6e 65 6e 74 72 69 65 |tries);.|.nentrie| |00000d80| 73 20 3d 20 74 74 6f 68 | 73 28 74 69 2c 20 6e 65 |s = ttoh|s(ti, ne| |00000d90| 6e 74 72 69 65 73 29 3b | 0d 09 0d 23 64 65 66 69 |ntries);|...#defi| |00000da0| 6e 65 20 5a 41 50 28 78 | 29 20 7b 69 66 28 78 29 |ne ZAP(x|) {if(x)| |00000db0| 7b 44 69 73 70 6f 73 50 | 74 72 28 78 29 3b 7d 20 |{DisposP|tr(x);} | |00000dc0| 78 20 3d 20 30 3b 7d 20 | 0d 09 0d 09 66 6f 72 28 |x = 0;} |....for(| |00000dd0| 65 6e 74 72 79 6e 6f 20 | 3d 20 30 3b 20 65 6e 74 |entryno |= 0; ent| |00000de0| 72 79 6e 6f 20 3c 20 6e | 65 6e 74 72 69 65 73 3b |ryno < n|entries;| |00000df0| 20 65 6e 74 72 79 6e 6f | 2b 2b 29 7b 0d 09 09 69 | entryno|++){...i| |00000e00| 66 28 28 65 72 72 20 3d | 20 52 65 61 64 54 49 46 |f((err =| ReadTIF| |00000e10| 46 45 6e 74 72 79 28 74 | 69 2c 20 6f 66 66 73 65 |FEntry(t|i, offse| |00000e20| 74 2c 20 26 65 6e 74 72 | 79 29 29 20 21 3d 20 30 |t, &entr|y)) != 0| |00000e30| 29 0d 09 09 09 72 65 74 | 75 72 6e 28 65 72 72 29 |)....ret|urn(err)| |00000e40| 3b 0d 09 09 6f 66 66 73 | 65 74 20 2b 3d 20 73 69 |;...offs|et += si| |00000e50| 7a 65 6f 66 28 65 6e 74 | 72 79 29 3b 0d 09 09 0d |zeof(ent|ry);....| |00000e60| 09 09 73 77 69 74 63 68 | 28 65 6e 74 72 79 2e 74 |..switch|(entry.t| |00000e70| 61 67 29 7b 0d 09 09 63 | 61 73 65 20 49 6d 61 67 |ag){...c|ase Imag| |00000e80| 65 57 69 64 74 68 3a 0d | 09 09 09 74 69 2d 3e 69 |eWidth:.|...ti->i| |00000e90| 6d 61 67 65 57 69 64 74 | 68 20 3d 20 50 61 72 73 |mageWidt|h = Pars| |00000ea0| 65 53 63 61 6c 61 72 28 | 74 69 2c 20 26 65 6e 74 |eScalar(|ti, &ent| |00000eb0| 72 79 29 3b 0d 09 09 09 | 62 72 65 61 6b 3b 0d 09 |ry);....|break;..| |00000ec0| 09 63 61 73 65 20 49 6d | 61 67 65 4c 65 6e 67 74 |.case Im|ageLengt| |00000ed0| 68 3a 0d 09 09 09 74 69 | 2d 3e 69 6d 61 67 65 4c |h:....ti|->imageL| |00000ee0| 65 6e 67 74 68 20 3d 20 | 50 61 72 73 65 53 63 61 |ength = |ParseSca| |00000ef0| 6c 61 72 28 74 69 2c 20 | 26 65 6e 74 72 79 29 3b |lar(ti, |&entry);| |00000f00| 0d 09 09 09 62 72 65 61 | 6b 3b 0d 09 09 63 61 73 |....brea|k;...cas| |00000f10| 65 20 42 69 74 73 50 65 | 72 53 61 6d 70 6c 65 3a |e BitsPe|rSample:| |00000f20| 0d 09 09 09 5a 41 50 28 | 74 69 2d 3e 62 69 74 73 |....ZAP(|ti->bits| |00000f30| 50 65 72 53 61 6d 70 6c | 65 29 3b 0d 09 09 09 74 |PerSampl|e);....t| |00000f40| 69 2d 3e 62 69 74 73 50 | 65 72 53 61 6d 70 6c 65 |i->bitsP|erSample| |00000f50| 20 3d 20 50 61 72 73 65 | 41 72 72 61 79 28 74 69 | = Parse|Array(ti| |00000f60| 2c 20 26 65 6e 74 72 79 | 29 3b 0d 09 09 09 62 72 |, &entry|);....br| |00000f70| 65 61 6b 3b 0d 09 09 63 | 61 73 65 20 43 6f 6c 6f |eak;...c|ase Colo| |00000f80| 72 4d 61 70 3a 0d 09 09 | 09 69 66 28 74 69 2d 3e |rMap:...|.if(ti->| |00000f90| 63 6f 6c 6f 72 4d 61 70 | 29 0d 09 09 09 09 44 69 |colorMap|).....Di| |00000fa0| 73 70 6f 73 43 54 61 62 | 6c 65 28 74 69 2d 3e 63 |sposCTab|le(ti->c| |00000fb0| 6f 6c 6f 72 4d 61 70 29 | 3b 0d 09 09 09 74 69 2d |olorMap)|;....ti-| |00000fc0| 3e 63 6f 6c 6f 72 4d 61 | 70 20 3d 20 30 3b 0d 09 |>colorMa|p = 0;..| |00000fd0| 09 09 63 6f 6c 6f 72 4d | 61 70 20 3d 20 50 61 72 |..colorM|ap = Par| |00000fe0| 73 65 41 72 72 61 79 28 | 74 69 2c 20 26 65 6e 74 |seArray(|ti, &ent| |00000ff0| 72 79 29 3b 0d 09 09 09 | 69 66 28 63 6f 6c 6f 72 |ry);....|if(color| |00001000| 4d 61 70 29 7b 0d 09 09 | 09 09 74 69 2d 3e 63 6f |Map){...|..ti->co| |00001010| 6c 6f 72 4d 61 70 20 3d | 20 54 72 61 6e 73 6c 61 |lorMap =| Transla| |00001020| 74 65 43 6f 6c 6f 72 4d | 61 70 28 63 6f 6c 6f 72 |teColorM|ap(color| |00001030| 4d 61 70 2c 20 65 6e 74 | 72 79 2e 6c 65 6e 67 74 |Map, ent|ry.lengt| |00001040| 68 20 2f 20 33 29 3b 0d | 09 09 09 09 44 69 73 70 |h / 3);.|....Disp| |00001050| 6f 73 50 74 72 28 63 6f | 6c 6f 72 4d 61 70 29 3b |osPtr(co|lorMap);| |00001060| 0d 09 09 09 09 63 6f 6c | 6f 72 4d 61 70 20 3d 20 |.....col|orMap = | |00001070| 30 3b 0d 09 09 09 09 69 | 66 28 74 69 2d 3e 63 6f |0;.....i|f(ti->co| |00001080| 6c 6f 72 4d 61 70 20 3d | 3d 20 30 29 0d 09 09 09 |lorMap =|= 0)....| |00001090| 09 09 54 49 46 46 45 72 | 72 6f 72 28 74 69 2c 20 |..TIFFEr|ror(ti, | |000010a0| 2d 31 2c 20 22 5c 70 43 | 6f 75 6c 64 20 6e 6f 74 |-1, "\pC|ould not| |000010b0| 20 6d 61 6b 65 20 63 6f | 6c 6f 72 20 6d 61 70 2e | make co|lor map.| |000010c0| 22 29 3b 0d 09 09 09 7d | 0d 09 09 09 62 72 65 61 |");....}|....brea| |000010d0| 6b 3b 0d 09 09 63 61 73 | 65 20 43 6f 6d 70 72 65 |k;...cas|e Compre| |000010e0| 73 73 69 6f 6e 3a 0d 09 | 09 09 74 69 2d 3e 63 6f |ssion:..|..ti->co| |000010f0| 6d 70 72 65 73 73 69 6f | 6e 20 3d 20 50 61 72 73 |mpressio|n = Pars| |00001100| 65 53 63 61 6c 61 72 28 | 74 69 2c 20 26 65 6e 74 |eScalar(|ti, &ent| |00001110| 72 79 29 3b 0d 09 09 09 | 62 72 65 61 6b 3b 0d 09 |ry);....|break;..| |00001120| 09 63 61 73 65 20 50 72 | 65 64 69 63 74 6f 72 3a |.case Pr|edictor:| |00001130| 0d 09 09 09 74 69 2d 3e | 70 72 65 64 69 63 74 6f |....ti->|predicto| |00001140| 72 20 3d 20 50 61 72 73 | 65 53 63 61 6c 61 72 28 |r = Pars|eScalar(| |00001150| 74 69 2c 20 26 65 6e 74 | 72 79 29 3b 0d 09 09 09 |ti, &ent|ry);....| |00001160| 62 72 65 61 6b 3b 0d 09 | 09 63 61 73 65 20 50 68 |break;..|.case Ph| |00001170| 6f 74 6f 6d 65 74 72 69 | 63 49 6e 74 65 72 70 72 |otometri|cInterpr| |00001180| 65 74 61 74 69 6f 6e 3a | 0d 09 09 09 74 69 2d 3e |etation:|....ti->| |00001190| 70 68 6f 74 6f 6d 65 74 | 72 69 63 49 6e 74 65 72 |photomet|ricInter| |000011a0| 70 72 65 74 61 74 69 6f | 6e 20 3d 20 50 61 72 73 |pretatio|n = Pars| |000011b0| 65 53 63 61 6c 61 72 28 | 74 69 2c 20 26 65 6e 74 |eScalar(|ti, &ent| |000011c0| 72 79 29 3b 0d 09 09 09 | 62 72 65 61 6b 3b 0d 09 |ry);....|break;..| |000011d0| 09 63 61 73 65 20 53 74 | 72 69 70 42 79 74 65 43 |.case St|ripByteC| |000011e0| 6f 75 6e 74 73 3a 0d 09 | 09 09 5a 41 50 28 74 69 |ounts:..|..ZAP(ti| |000011f0| 2d 3e 73 74 72 69 70 42 | 79 74 65 43 6f 75 6e 74 |->stripB|yteCount| |00001200| 73 29 3b 0d 09 09 09 74 | 69 2d 3e 73 74 72 69 70 |s);....t|i->strip| |00001210| 42 79 74 65 43 6f 75 6e | 74 73 20 3d 20 50 61 72 |ByteCoun|ts = Par| |00001220| 73 65 41 72 72 61 79 28 | 74 69 2c 20 26 65 6e 74 |seArray(|ti, &ent| |00001230| 72 79 29 3b 0d 09 09 09 | 62 72 65 61 6b 3b 0d 09 |ry);....|break;..| |00001240| 09 63 61 73 65 20 53 74 | 72 69 70 4f 66 66 73 65 |.case St|ripOffse| |00001250| 74 73 3a 0d 09 09 09 5a | 41 50 28 74 69 2d 3e 73 |ts:....Z|AP(ti->s| |00001260| 74 72 69 70 4f 66 66 73 | 65 74 73 29 3b 0d 09 09 |tripOffs|ets);...| |00001270| 09 74 69 2d 3e 73 74 72 | 69 70 4f 66 66 73 65 74 |.ti->str|ipOffset| |00001280| 73 20 3d 20 50 61 72 73 | 65 41 72 72 61 79 28 74 |s = Pars|eArray(t| |00001290| 69 2c 20 26 65 6e 74 72 | 79 29 3b 0d 09 09 09 62 |i, &entr|y);....b| |000012a0| 72 65 61 6b 3b 0d 09 09 | 63 61 73 65 20 53 61 6d |reak;...|case Sam| |000012b0| 70 6c 65 73 50 65 72 50 | 69 78 65 6c 3a 0d 09 09 |plesPerP|ixel:...| |000012c0| 09 74 69 2d 3e 73 61 6d | 70 6c 65 73 50 65 72 50 |.ti->sam|plesPerP| |000012d0| 69 78 65 6c 20 3d 20 50 | 61 72 73 65 53 63 61 6c |ixel = P|arseScal| |000012e0| 61 72 28 74 69 2c 20 26 | 65 6e 74 72 79 29 3b 0d |ar(ti, &|entry);.| |000012f0| 09 09 09 62 72 65 61 6b | 3b 0d 09 09 63 61 73 65 |...break|;...case| |00001300| 20 52 6f 77 73 50 65 72 | 53 74 72 69 70 3a 0d 09 | RowsPer|Strip:..| |00001310| 09 09 74 69 2d 3e 72 6f | 77 73 50 65 72 53 74 72 |..ti->ro|wsPerStr| |00001320| 69 70 20 3d 20 50 61 72 | 73 65 53 63 61 6c 61 72 |ip = Par|seScalar| |00001330| 28 74 69 2c 20 26 65 6e | 74 72 79 29 3b 0d 09 09 |(ti, &en|try);...| |00001340| 09 62 72 65 61 6b 3b 0d | 09 09 63 61 73 65 20 50 |.break;.|..case P| |00001350| 6c 61 6e 61 72 43 6f 6e | 66 69 67 75 72 61 74 69 |lanarCon|figurati| |00001360| 6f 6e 3a 0d 09 09 09 74 | 69 2d 3e 70 6c 61 6e 61 |on:....t|i->plana| |00001370| 72 43 6f 6e 66 69 67 75 | 72 61 74 69 6f 6e 20 3d |rConfigu|ration =| |00001380| 20 50 61 72 73 65 53 63 | 61 6c 61 72 28 74 69 2c | ParseSc|alar(ti,| |00001390| 20 26 65 6e 74 72 79 29 | 3b 0d 09 09 09 62 72 65 | &entry)|;....bre| |000013a0| 61 6b 3b 0d 09 09 63 61 | 73 65 20 46 69 6c 6c 4f |ak;...ca|se FillO| |000013b0| 72 64 65 72 3a 0d 09 09 | 09 74 69 2d 3e 66 69 6c |rder:...|.ti->fil| |000013c0| 6c 4f 72 64 65 72 20 3d | 20 50 61 72 73 65 53 63 |lOrder =| ParseSc| |000013d0| 61 6c 61 72 28 74 69 2c | 20 26 65 6e 74 72 79 29 |alar(ti,| &entry)| |000013e0| 3b 0d 09 09 09 62 72 65 | 61 6b 3b 0d 09 09 63 61 |;....bre|ak;...ca| |000013f0| 73 65 20 54 36 4f 70 74 | 69 6f 6e 73 3a 0d 09 09 |se T6Opt|ions:...| |00001400| 09 74 69 2d 3e 74 36 4f | 70 74 69 6f 6e 73 20 3d |.ti->t6O|ptions =| |00001410| 20 50 61 72 73 65 53 63 | 61 6c 61 72 28 74 69 2c | ParseSc|alar(ti,| |00001420| 20 26 65 6e 74 72 79 29 | 3b 0d 09 09 09 62 72 65 | &entry)|;....bre| |00001430| 61 6b 3b 0d 23 69 66 64 | 65 66 20 54 49 46 46 5f |ak;.#ifd|ef TIFF_| |00001440| 50 52 49 4e 54 46 53 0d | 09 09 64 65 66 61 75 6c |PRINTFS.|..defaul| |00001450| 74 3a 0d 09 09 09 70 72 | 69 6e 74 66 28 22 74 61 |t:....pr|intf("ta| |00001460| 67 20 25 64 2c 20 74 79 | 70 65 20 25 64 2c 20 6c |g %d, ty|pe %d, l| |00001470| 65 6e 67 74 68 20 25 6c | 64 2c 20 76 61 6c 75 65 |ength %l|d, value| |00001480| 20 25 6c 64 2f 30 78 25 | 6c 78 5c 6e 22 2c 0d 09 | %ld/0x%|lx\n",..| |00001490| 09 09 09 65 6e 74 72 79 | 2e 74 61 67 2c 20 65 6e |...entry|.tag, en| |000014a0| 74 72 79 2e 74 79 70 65 | 2c 20 65 6e 74 72 79 2e |try.type|, entry.| |000014b0| 6c 65 6e 67 74 68 2c 20 | 65 6e 74 72 79 2e 6f 66 |length, |entry.of| |000014c0| 66 73 65 74 2c 20 65 6e | 74 72 79 2e 6f 66 66 73 |fset, en|try.offs| |000014d0| 65 74 29 3b 0d 23 65 6e | 64 69 66 0d 09 09 7d 0d |et);.#en|dif...}.| |000014e0| 09 7d 0d 09 0d 09 2f 2a | 20 53 6f 6d 65 20 4e 65 |.}..../*| Some Ne| |000014f0| 58 54 20 70 72 6f 67 72 | 61 6d 20 67 65 6e 65 72 |XT progr|am gener| |00001500| 61 74 65 73 20 62 6f 67 | 75 73 20 50 6c 61 6e 61 |ates bog|us Plana| |00001510| 72 43 6f 6e 66 69 67 75 | 72 61 74 69 6f 6e 73 20 |rConfigu|rations | |00001520| 6f 66 20 32 2e 20 2a 2f | 0d 09 69 66 28 74 69 2d |of 2. */|..if(ti-| |00001530| 3e 73 61 6d 70 6c 65 73 | 50 65 72 50 69 78 65 6c |>samples|PerPixel| |00001540| 20 3d 3d 20 31 20 26 26 | 20 74 69 2d 3e 70 6c 61 | == 1 &&| ti->pla| |00001550| 6e 61 72 43 6f 6e 66 69 | 67 75 72 61 74 69 6f 6e |narConfi|guration| |00001560| 20 3d 3d 20 32 29 0d 09 | 09 74 69 2d 3e 70 6c 61 | == 2)..|.ti->pla| |00001570| 6e 61 72 43 6f 6e 66 69 | 67 75 72 61 74 69 6f 6e |narConfi|guration| |00001580| 20 3d 20 31 3b 0d 09 0d | 09 69 66 28 74 69 2d 3e | = 1;...|.if(ti->| |00001590| 72 6f 77 73 50 65 72 53 | 74 72 69 70 20 3e 20 74 |rowsPerS|trip > t| |000015a0| 69 2d 3e 69 6d 61 67 65 | 4c 65 6e 67 74 68 29 0d |i->image|Length).| |000015b0| 09 09 74 69 2d 3e 72 6f | 77 73 50 65 72 53 74 72 |..ti->ro|wsPerStr| |000015c0| 69 70 20 3d 20 74 69 2d | 3e 69 6d 61 67 65 4c 65 |ip = ti-|>imageLe| |000015d0| 6e 67 74 68 3b 0d 09 74 | 69 2d 3e 73 74 72 69 70 |ngth;..t|i->strip| |000015e0| 73 50 65 72 49 6d 61 67 | 65 20 3d 20 28 74 69 2d |sPerImag|e = (ti-| |000015f0| 3e 69 6d 61 67 65 4c 65 | 6e 67 74 68 20 2b 20 74 |>imageLe|ngth + t| |00001600| 69 2d 3e 72 6f 77 73 50 | 65 72 53 74 72 69 70 20 |i->rowsP|erStrip | |00001610| 2d 20 31 29 20 2f 20 74 | 69 2d 3e 72 6f 77 73 50 |- 1) / t|i->rowsP| |00001620| 65 72 53 74 72 69 70 3b | 0d 0d 09 2f 2a 0d 09 20 |erStrip;|.../*.. | |00001630| 2a 20 57 65 20 6e 65 65 | 64 20 61 20 63 6f 6c 6f |* We nee|d a colo| |00001640| 72 20 6d 61 70 20 66 6f | 72 20 67 72 61 79 2d 73 |r map fo|r gray-s| |00001650| 63 61 6c 65 20 69 6d 61 | 67 65 73 20 64 65 65 70 |cale ima|ges deep| |00001660| 65 72 20 74 68 61 6e 20 | 6f 6e 65 20 62 69 74 2e |er than |one bit.| |00001670| 0d 09 20 2a 2f 0d 09 69 | 66 28 74 69 2d 3e 63 6f |.. */..i|f(ti->co| |00001680| 6c 6f 72 4d 61 70 20 3d | 3d 20 30 20 26 26 0d 09 |lorMap =|= 0 &&..| |00001690| 20 20 20 74 69 2d 3e 73 | 61 6d 70 6c 65 73 50 65 | ti->s|amplesPe| |000016a0| 72 50 69 78 65 6c 20 3d | 3d 20 31 20 26 26 0d 09 |rPixel =|= 1 &&..| |000016b0| 20 20 20 74 69 2d 3e 62 | 69 74 73 50 65 72 53 61 | ti->b|itsPerSa| |000016c0| 6d 70 6c 65 5b 30 5d 20 | 3c 3d 20 38 20 26 26 0d |mple[0] |<= 8 &&.| |000016d0| 09 20 20 20 74 69 2d 3e | 62 69 74 73 50 65 72 53 |. ti->|bitsPerS| |000016e0| 61 6d 70 6c 65 5b 30 5d | 20 3e 20 31 20 26 26 0d |ample[0]| > 1 &&.| |000016f0| 09 20 20 20 28 74 69 2d | 3e 70 68 6f 74 6f 6d 65 |. (ti-|>photome| |00001700| 74 72 69 63 49 6e 74 65 | 72 70 72 65 74 61 74 69 |tricInte|rpretati| |00001710| 6f 6e 20 3d 3d 20 50 49 | 5a 65 72 6f 49 73 57 68 |on == PI|ZeroIsWh| |00001720| 69 74 65 20 7c 7c 0d 09 | 09 74 69 2d 3e 70 68 6f |ite ||..|.ti->pho| |00001730| 74 6f 6d 65 74 72 69 63 | 49 6e 74 65 72 70 72 65 |tometric|Interpre| |00001740| 74 61 74 69 6f 6e 20 3d | 3d 20 50 49 5a 65 72 6f |tation =|= PIZero| |00001750| 49 73 42 6c 61 63 6b 29 | 29 7b 0d 09 09 74 69 2d |IsBlack)|){...ti-| |00001760| 3e 63 6f 6c 6f 72 4d 61 | 70 20 3d 20 4d 61 6b 65 |>colorMa|p = Make| |00001770| 47 72 61 79 54 61 62 6c | 65 28 74 69 2d 3e 62 69 |GrayTabl|e(ti->bi| |00001780| 74 73 50 65 72 53 61 6d | 70 6c 65 5b 30 5d 2c 0d |tsPerSam|ple[0],.| |00001790| 09 09 09 09 09 09 09 09 | 09 20 74 69 2d 3e 70 68 |........|. ti->ph| |000017a0| 6f 74 6f 6d 65 74 72 69 | 63 49 6e 74 65 72 70 72 |otometri|cInterpr| |000017b0| 65 74 61 74 69 6f 6e 20 | 3d 3d 20 50 49 5a 65 72 |etation |== PIZer| |000017c0| 6f 49 73 57 68 69 74 65 | 29 3b 0d 09 09 69 66 28 |oIsWhite|);...if(| |000017d0| 74 69 2d 3e 63 6f 6c 6f | 72 4d 61 70 20 3d 3d 20 |ti->colo|rMap == | |000017e0| 30 29 0d 09 09 09 54 49 | 46 46 45 72 72 6f 72 28 |0)....TI|FFError(| |000017f0| 74 69 2c 20 2d 31 2c 20 | 22 5c 70 43 6f 75 6c 64 |ti, -1, |"\pCould| |00001800| 20 6e 6f 74 20 6d 61 6b | 65 20 67 72 61 79 2d 73 | not mak|e gray-s| |00001810| 63 61 6c 65 20 63 6f 6c | 6f 72 20 6d 61 70 2e 22 |cale col|or map."| |00001820| 29 3b 0d 09 7d 0d 09 09 | 0d 09 74 69 66 66 5f 72 |);..}...|..tiff_r| |00001830| 65 61 64 28 74 69 2c 20 | 6f 66 66 73 65 74 2c 20 |ead(ti, |offset, | |00001840| 26 6e 65 78 74 6f 66 66 | 73 65 74 2c 20 73 69 7a |&nextoff|set, siz| |00001850| 65 6f 66 28 6e 65 78 74 | 6f 66 66 73 65 74 29 29 |eof(next|offset))| |00001860| 3b 0d 09 74 69 2d 3e 6e | 65 78 74 4f 66 66 73 65 |;..ti->n|extOffse| |00001870| 74 20 3d 20 74 74 6f 68 | 6c 28 74 69 2c 20 6e 65 |t = ttoh|l(ti, ne| |00001880| 78 74 6f 66 66 73 65 74 | 29 3b 0d 09 0d 09 72 65 |xtoffset|);....re| |00001890| 74 75 72 6e 28 30 29 3b | 0d 7d 0d 0d 2f 2a 0d 20 |turn(0);|.}../*. | |000018a0| 2a 20 72 65 74 75 72 6e | 73 20 30 20 69 66 20 4f |* return|s 0 if O| |000018b0| 4b 2c 20 6f 72 20 61 20 | 6e 65 67 61 74 69 76 65 |K, or a |negative| |000018c0| 20 65 72 72 6f 72 20 23 | 2e 0d 20 2a 2f 0d 4f 53 | error #|.. */.OS| |000018d0| 45 72 72 0d 52 65 61 64 | 54 49 46 46 45 6e 74 72 |Err.Read|TIFFEntr| |000018e0| 79 28 54 49 46 46 50 74 | 72 20 74 69 2c 20 6c 6f |y(TIFFPt|r ti, lo| |000018f0| 6e 67 20 6f 66 66 73 65 | 74 2c 20 73 74 72 75 63 |ng offse|t, struc| |00001900| 74 20 54 49 46 46 45 6e | 74 72 79 20 2a 65 70 29 |t TIFFEn|try *ep)| |00001910| 0d 7b 0d 09 4f 53 45 72 | 72 20 65 72 72 3b 0d 09 |.{..OSEr|r err;..| |00001920| 0d 09 69 66 28 28 65 72 | 72 20 3d 20 74 69 66 66 |..if((er|r = tiff| |00001930| 5f 72 65 61 64 28 74 69 | 2c 20 6f 66 66 73 65 74 |_read(ti|, offset| |00001940| 2c 20 65 70 2c 20 73 69 | 7a 65 6f 66 28 73 74 72 |, ep, si|zeof(str| |00001950| 75 63 74 20 54 49 46 46 | 45 6e 74 72 79 29 29 29 |uct TIFF|Entry)))| |00001960| 20 21 3d 20 30 29 0d 09 | 09 72 65 74 75 72 6e 28 | != 0)..|.return(| |00001970| 65 72 72 29 3b 0d 09 65 | 70 2d 3e 74 61 67 20 3d |err);..e|p->tag =| |00001980| 20 74 74 6f 68 73 28 74 | 69 2c 20 65 70 2d 3e 74 | ttohs(t|i, ep->t| |00001990| 61 67 29 3b 0d 09 65 70 | 2d 3e 74 79 70 65 20 3d |ag);..ep|->type =| |000019a0| 20 74 74 6f 68 73 28 74 | 69 2c 20 65 70 2d 3e 74 | ttohs(t|i, ep->t| |000019b0| 79 70 65 29 3b 0d 09 65 | 70 2d 3e 6c 65 6e 67 74 |ype);..e|p->lengt| |000019c0| 68 20 3d 20 74 74 6f 68 | 6c 28 74 69 2c 20 65 70 |h = ttoh|l(ti, ep| |000019d0| 2d 3e 6c 65 6e 67 74 68 | 29 3b 0d 09 72 65 74 75 |->length|);..retu| |000019e0| 72 6e 28 30 29 3b 0d 7d | 0d 0d 2f 2a 0d 20 2a 20 |rn(0);.}|../*. * | |000019f0| 74 72 69 65 73 20 74 6f | 20 69 6e 74 65 72 70 72 |tries to| interpr| |00001a00| 65 74 20 61 6e 20 65 6e | 74 72 79 20 61 73 20 61 |et an en|try as a| |00001a10| 20 73 69 6e 67 6c 65 20 | 33 32 2d 62 69 74 20 69 | single |32-bit i| |00001a20| 6e 74 65 67 65 72 20 76 | 61 6c 75 65 2e 0d 20 2a |nteger v|alue.. *| |00001a30| 20 63 61 6e 20 68 61 6e | 64 6c 65 20 65 69 74 68 | can han|dle eith| |00001a40| 65 72 20 54 49 46 46 5f | 53 48 4f 52 54 20 6f 72 |er TIFF_|SHORT or| |00001a50| 20 54 49 46 46 5f 4c 4f | 4e 47 2e 0d 20 2a 20 61 | TIFF_LO|NG.. * a| |00001a60| 73 73 75 6d 65 73 20 52 | 65 61 64 54 49 46 46 45 |ssumes R|eadTIFFE| |00001a70| 6e 74 72 79 28 29 20 68 | 61 73 20 61 6c 72 65 61 |ntry() h|as alrea| |00001a80| 64 79 20 61 64 6a 75 73 | 74 65 64 20 62 79 74 65 |dy adjus|ted byte| |00001a90| 20 6f 72 64 65 72 20 6f | 66 20 74 61 67 2c 20 74 | order o|f tag, t| |00001aa0| 79 70 65 2c 20 61 6e 64 | 20 6c 65 6e 67 74 68 2e |ype, and| length.| |00001ab0| 0d 20 2a 20 72 65 74 75 | 72 6e 73 20 30 20 69 66 |. * retu|rns 0 if| |00001ac0| 20 4f 4b 2c 20 6f 72 20 | 61 20 6e 65 67 61 74 69 | OK, or |a negati| |00001ad0| 76 65 20 65 72 72 6f 72 | 20 23 2e 0d 20 2a 20 4f |ve error| #.. * O| |00001ae0| 6e 20 74 68 65 20 4d 61 | 63 2c 20 76 61 6c 75 65 |n the Ma|c, value| |00001af0| 73 20 61 70 70 65 61 72 | 20 69 6e 20 74 68 65 20 |s appear| in the | |00001b00| 68 69 67 68 65 73 74 20 | 62 69 74 73 20 6f 66 20 |highest |bits of | |00001b10| 6f 66 66 73 65 74 2e 0d | 20 2a 2f 0d 6c 6f 6e 67 |offset..| */.long| |00001b20| 0d 50 61 72 73 65 53 63 | 61 6c 61 72 28 54 49 46 |.ParseSc|alar(TIF| |00001b30| 46 50 74 72 20 74 69 2c | 20 73 74 72 75 63 74 20 |FPtr ti,| struct | |00001b40| 54 49 46 46 45 6e 74 72 | 79 20 2a 65 70 29 0d 7b |TIFFEntr|y *ep).{| |00001b50| 0d 09 69 66 28 65 70 2d | 3e 6c 65 6e 67 74 68 20 |..if(ep-|>length | |00001b60| 21 3d 20 31 29 0d 09 09 | 72 65 74 75 72 6e 28 2d |!= 1)...|return(-| |00001b70| 31 29 3b 0d 09 69 66 28 | 65 70 2d 3e 74 79 70 65 |1);..if(|ep->type| |00001b80| 20 3d 3d 20 54 49 46 46 | 5f 42 59 54 45 29 7b 0d | == TIFF|_BYTE){.| |00001b90| 09 09 72 65 74 75 72 6e | 28 28 65 70 2d 3e 6f 66 |..return|((ep->of| |00001ba0| 66 73 65 74 20 3e 3e 20 | 32 34 29 20 26 20 30 78 |fset >> |24) & 0x| |00001bb0| 66 66 29 3b 0d 09 7d 20 | 65 6c 73 65 20 69 66 28 |ff);..} |else if(| |00001bc0| 65 70 2d 3e 74 79 70 65 | 20 3d 3d 20 54 49 46 46 |ep->type| == TIFF| |00001bd0| 5f 53 48 4f 52 54 29 7b | 0d 09 09 72 65 74 75 72 |_SHORT){|...retur| |00001be0| 6e 28 74 74 6f 68 73 28 | 74 69 2c 20 28 65 70 2d |n(ttohs(|ti, (ep-| |00001bf0| 3e 6f 66 66 73 65 74 20 | 3e 3e 20 31 36 29 20 26 |>offset |>> 16) &| |00001c00| 20 30 78 66 66 66 66 29 | 29 3b 0d 09 7d 20 65 6c | 0xffff)|);..} el| |00001c10| 73 65 20 69 66 28 65 70 | 2d 3e 74 79 70 65 20 3d |se if(ep|->type =| |00001c20| 3d 20 54 49 46 46 5f 4c | 4f 4e 47 29 7b 0d 09 09 |= TIFF_L|ONG){...| |00001c30| 72 65 74 75 72 6e 28 74 | 74 6f 68 6c 28 74 69 2c |return(t|tohl(ti,| |00001c40| 20 65 70 2d 3e 6f 66 66 | 73 65 74 29 29 3b 0d 09 | ep->off|set));..| |00001c50| 7d 20 65 6c 73 65 20 7b | 0d 09 09 54 49 46 46 45 |} else {|...TIFFE| |00001c60| 72 72 6f 72 28 74 69 2c | 20 2d 31 2c 20 22 5c 70 |rror(ti,| -1, "\p| |00001c70| 55 6e 6b 6e 6f 77 6e 20 | 76 61 6c 75 65 20 74 79 |Unknown |value ty| |00001c80| 70 65 2e 22 29 3b 0d 09 | 09 72 65 74 75 72 6e 28 |pe.");..|.return(| |00001c90| 2d 31 29 3b 0d 09 7d 0d | 7d 0d 0d 2f 2a 0d 20 2a |-1);..}.|}../*. *| |00001ca0| 20 52 65 74 75 72 6e 73 | 20 61 6e 20 61 72 72 61 | Returns| an arra| |00001cb0| 79 20 6f 66 20 6c 6f 6e | 67 73 2c 20 6e 6f 20 6d |y of lon|gs, no m| |00001cc0| 61 74 74 65 72 20 77 68 | 61 74 20 74 68 65 20 73 |atter wh|at the s| |00001cd0| 69 7a 65 20 6f 66 20 74 | 68 65 20 61 72 72 61 79 |ize of t|he array| |00001ce0| 20 65 6c 65 6d 65 6e 74 | 2e 0d 20 2a 20 4e 6f 74 | element|.. * Not| |00001cf0| 65 20 74 68 61 74 20 69 | 66 20 74 68 65 20 61 72 |e that i|f the ar| |00001d00| 72 61 79 20 66 69 74 73 | 20 69 6e 20 74 68 65 20 |ray fits| in the | |00001d10| 6f 66 66 73 65 74 20 66 | 69 65 6c 64 2c 20 69 74 |offset f|ield, it| |00001d20| 20 77 69 6c 6c 20 62 65 | 20 74 68 65 72 65 2c 20 | will be| there, | |00001d30| 69 6e 20 74 68 65 0d 20 | 2a 20 68 69 67 68 2d 6f |in the. |* high-o| |00001d40| 72 64 65 72 20 62 69 74 | 73 2c 20 77 69 74 68 20 |rder bit|s, with | |00001d50| 65 6c 65 6d 65 6e 74 20 | 7a 65 72 6f 20 68 69 67 |element |zero hig| |00001d60| 68 65 73 74 2e 0d 20 2a | 2f 0d 6c 6f 6e 67 20 2a |hest.. *|/.long *| |00001d70| 0d 50 61 72 73 65 41 72 | 72 61 79 28 54 49 46 46 |.ParseAr|ray(TIFF| |00001d80| 50 74 72 20 74 69 2c 20 | 73 74 72 75 63 74 20 54 |Ptr ti, |struct T| |00001d90| 49 46 46 45 6e 74 72 79 | 20 2a 65 70 29 0d 7b 0d |IFFEntry| *ep).{.| |00001da0| 09 6c 6f 6e 67 20 6e 62 | 79 74 65 73 2c 20 69 3b |.long nb|ytes, i;| |00001db0| 0d 09 75 6e 73 69 67 6e | 65 64 20 63 68 61 72 20 |..unsign|ed char | |00001dc0| 2a 63 70 20 3d 20 30 3b | 0d 09 75 6e 73 69 67 6e |*cp = 0;|..unsign| |00001dd0| 65 64 20 73 68 6f 72 74 | 20 2a 73 70 20 3d 20 30 |ed short| *sp = 0| |00001de0| 3b 0d 09 6c 6f 6e 67 20 | 2a 6c 70 20 3d 20 30 3b |;..long |*lp = 0;| |00001df0| 0d 09 0d 09 69 66 28 65 | 70 2d 3e 6c 65 6e 67 74 |....if(e|p->lengt| |00001e00| 68 20 3c 20 30 29 0d 09 | 09 67 6f 74 6f 20 62 61 |h < 0)..|.goto ba| |00001e10| 64 3b 0d 09 09 0d 09 6c | 70 20 3d 20 28 6c 6f 6e |d;.....l|p = (lon| |00001e20| 67 20 2a 29 20 4e 65 77 | 50 74 72 28 65 70 2d 3e |g *) New|Ptr(ep->| |00001e30| 6c 65 6e 67 74 68 20 2a | 20 73 69 7a 65 6f 66 28 |length *| sizeof(| |00001e40| 6c 6f 6e 67 29 29 3b 0d | 09 69 66 28 6c 70 20 3d |long));.|.if(lp =| |00001e50| 3d 20 30 29 0d 09 09 67 | 6f 74 6f 20 62 61 64 3b |= 0)...g|oto bad;| |00001e60| 0d 09 09 0d 09 69 66 28 | 65 70 2d 3e 74 79 70 65 |.....if(|ep->type| |00001e70| 20 3d 3d 20 54 49 46 46 | 5f 42 59 54 45 29 7b 0d | == TIFF|_BYTE){.| |00001e80| 09 09 6e 62 79 74 65 73 | 20 3d 20 65 70 2d 3e 6c |..nbytes| = ep->l| |00001e90| 65 6e 67 74 68 3b 0d 09 | 09 69 66 28 6e 62 79 74 |ength;..|.if(nbyt| |00001ea0| 65 73 20 3c 3d 20 34 29 | 7b 0d 09 09 09 66 6f 72 |es <= 4)|{....for| |00001eb0| 28 69 20 3d 20 30 3b 20 | 69 20 3c 20 65 70 2d 3e |(i = 0; |i < ep->| |00001ec0| 6c 65 6e 67 74 68 3b 20 | 69 2b 2b 29 0d 09 09 09 |length; |i++)....| |00001ed0| 09 6c 70 5b 69 5d 20 3d | 20 28 65 70 2d 3e 6f 66 |.lp[i] =| (ep->of| |00001ee0| 66 73 65 74 20 3e 3e 20 | 28 32 34 20 2d 20 28 69 |fset >> |(24 - (i| |00001ef0| 20 2a 20 38 29 29 29 20 | 26 20 30 78 66 66 3b 0d | * 8))) |& 0xff;.| |00001f00| 09 09 7d 20 65 6c 73 65 | 20 7b 0d 09 09 09 63 70 |..} else| {....cp| |00001f10| 20 3d 20 28 75 6e 73 69 | 67 6e 65 64 20 63 68 61 | = (unsi|gned cha| |00001f20| 72 20 2a 29 20 4e 65 77 | 50 74 72 28 6e 62 79 74 |r *) New|Ptr(nbyt| |00001f30| 65 73 29 3b 0d 09 09 09 | 69 66 28 63 70 20 3d 3d |es);....|if(cp ==| |00001f40| 20 30 29 0d 09 09 09 09 | 67 6f 74 6f 20 62 61 64 | 0).....|goto bad| |00001f50| 3b 0d 09 09 09 69 66 28 | 74 69 66 66 5f 72 65 61 |;....if(|tiff_rea| |00001f60| 64 28 74 69 2c 20 74 74 | 6f 68 6c 28 74 69 2c 20 |d(ti, tt|ohl(ti, | |00001f70| 65 70 2d 3e 6f 66 66 73 | 65 74 29 2c 20 28 63 68 |ep->offs|et), (ch| |00001f80| 61 72 20 2a 29 63 70 2c | 20 6e 62 79 74 65 73 29 |ar *)cp,| nbytes)| |00001f90| 20 21 3d 20 30 29 0d 09 | 09 09 09 67 6f 74 6f 20 | != 0)..|...goto | |00001fa0| 62 61 64 3b 0d 09 09 09 | 66 6f 72 28 69 20 3d 20 |bad;....|for(i = | |00001fb0| 30 3b 20 69 20 3c 20 65 | 70 2d 3e 6c 65 6e 67 74 |0; i < e|p->lengt| |00001fc0| 68 3b 20 69 2b 2b 29 0d | 09 09 09 09 6c 70 5b 69 |h; i++).|....lp[i| |00001fd0| 5d 20 3d 20 63 70 5b 69 | 5d 3b 0d 09 09 7d 0d 09 |] = cp[i|];...}..| |00001fe0| 7d 20 65 6c 73 65 20 69 | 66 28 65 70 2d 3e 74 79 |} else i|f(ep->ty| |00001ff0| 70 65 20 3d 3d 20 54 49 | 46 46 5f 53 48 4f 52 54 |pe == TI|FF_SHORT| |00002000| 29 7b 0d 09 09 6e 62 79 | 74 65 73 20 3d 20 65 70 |){...nby|tes = ep| |00002010| 2d 3e 6c 65 6e 67 74 68 | 20 2a 20 32 3b 0d 09 09 |->length| * 2;...| |00002020| 69 66 28 6e 62 79 74 65 | 73 20 3c 3d 20 34 29 7b |if(nbyte|s <= 4){| |00002030| 0d 09 09 09 66 6f 72 28 | 69 20 3d 20 30 3b 20 69 |....for(|i = 0; i| |00002040| 20 3c 20 65 70 2d 3e 6c | 65 6e 67 74 68 3b 20 69 | < ep->l|ength; i| |00002050| 2b 2b 29 0d 09 09 09 09 | 6c 70 5b 69 5d 20 3d 20 |++).....|lp[i] = | |00002060| 74 74 6f 68 73 28 74 69 | 2c 20 65 70 2d 3e 6f 66 |ttohs(ti|, ep->of| |00002070| 66 73 65 74 20 3e 3e 20 | 28 31 36 20 2d 20 28 69 |fset >> |(16 - (i| |00002080| 20 2a 20 31 36 29 29 29 | 3b 0d 09 09 7d 20 65 6c | * 16)))|;...} el| |00002090| 73 65 20 7b 0d 09 09 09 | 73 70 20 3d 20 28 75 6e |se {....|sp = (un| |000020a0| 73 69 67 6e 65 64 20 73 | 68 6f 72 74 20 2a 29 20 |signed s|hort *) | |000020b0| 4e 65 77 50 74 72 28 6e | 62 79 74 65 73 29 3b 0d |NewPtr(n|bytes);.| |000020c0| 09 09 09 69 66 28 73 70 | 20 3d 3d 20 30 29 0d 09 |...if(sp| == 0)..| |000020d0| 09 09 09 67 6f 74 6f 20 | 62 61 64 3b 0d 09 09 09 |...goto |bad;....| |000020e0| 69 66 28 74 69 66 66 5f | 72 65 61 64 28 74 69 2c |if(tiff_|read(ti,| |000020f0| 20 74 74 6f 68 6c 28 74 | 69 2c 20 65 70 2d 3e 6f | ttohl(t|i, ep->o| |00002100| 66 66 73 65 74 29 2c 20 | 28 63 68 61 72 20 2a 29 |ffset), |(char *)| |00002110| 73 70 2c 20 6e 62 79 74 | 65 73 29 20 21 3d 20 30 |sp, nbyt|es) != 0| |00002120| 29 0d 09 09 09 09 67 6f | 74 6f 20 62 61 64 3b 0d |).....go|to bad;.| |00002130| 09 09 09 66 6f 72 28 69 | 20 3d 20 30 3b 20 69 20 |...for(i| = 0; i | |00002140| 3c 20 65 70 2d 3e 6c 65 | 6e 67 74 68 3b 20 69 2b |< ep->le|ngth; i+| |00002150| 2b 29 0d 09 09 09 09 6c | 70 5b 69 5d 20 3d 20 74 |+).....l|p[i] = t| |00002160| 74 6f 68 73 28 74 69 2c | 20 73 70 5b 69 5d 29 3b |tohs(ti,| sp[i]);| |00002170| 0d 09 09 7d 0d 09 7d 20 | 65 6c 73 65 20 69 66 28 |...}..} |else if(| |00002180| 65 70 2d 3e 74 79 70 65 | 20 3d 3d 20 54 49 46 46 |ep->type| == TIFF| |00002190| 5f 4c 4f 4e 47 29 7b 0d | 09 09 6e 62 79 74 65 73 |_LONG){.|..nbytes| |000021a0| 20 3d 20 65 70 2d 3e 6c | 65 6e 67 74 68 20 2a 20 | = ep->l|ength * | |000021b0| 34 3b 0d 09 09 69 66 28 | 6e 62 79 74 65 73 20 3c |4;...if(|nbytes <| |000021c0| 3d 20 34 29 7b 0d 09 09 | 09 6c 70 5b 30 5d 20 3d |= 4){...|.lp[0] =| |000021d0| 20 74 74 6f 68 6c 28 74 | 69 2c 20 65 70 2d 3e 6f | ttohl(t|i, ep->o| |000021e0| 66 66 73 65 74 29 3b 0d | 09 09 7d 20 65 6c 73 65 |ffset);.|..} else| |000021f0| 20 7b 0d 09 09 09 69 66 | 28 74 69 66 66 5f 72 65 | {....if|(tiff_re| |00002200| 61 64 28 74 69 2c 20 74 | 74 6f 68 6c 28 74 69 2c |ad(ti, t|tohl(ti,| |00002210| 20 65 70 2d 3e 6f 66 66 | 73 65 74 29 2c 20 28 63 | ep->off|set), (c| |00002220| 68 61 72 20 2a 29 6c 70 | 2c 20 6e 62 79 74 65 73 |har *)lp|, nbytes| |00002230| 29 20 21 3d 20 30 29 0d | 09 09 09 09 67 6f 74 6f |) != 0).|....goto| |00002240| 20 62 61 64 3b 0d 09 09 | 09 66 6f 72 28 69 20 3d | bad;...|.for(i =| |00002250| 20 30 3b 20 69 20 3c 20 | 65 70 2d 3e 6c 65 6e 67 | 0; i < |ep->leng| |00002260| 74 68 3b 20 69 2b 2b 29 | 0d 09 09 09 09 6c 70 5b |th; i++)|.....lp[| |00002270| 69 5d 20 3d 20 74 74 6f | 68 6c 28 74 69 2c 20 6c |i] = tto|hl(ti, l| |00002280| 70 5b 69 5d 29 3b 0d 09 | 09 7d 0d 09 7d 20 65 6c |p[i]);..|.}..} el| |00002290| 73 65 20 7b 0d 09 09 67 | 6f 74 6f 20 62 61 64 3b |se {...g|oto bad;| |000022a0| 0d 09 7d 0d 09 0d 09 69 | 66 28 63 70 29 0d 09 09 |..}....i|f(cp)...| |000022b0| 44 69 73 70 6f 73 50 74 | 72 28 63 70 29 3b 0d 09 |DisposPt|r(cp);..| |000022c0| 69 66 28 73 70 29 0d 09 | 09 44 69 73 70 6f 73 50 |if(sp)..|.DisposP| |000022d0| 74 72 28 73 70 29 3b 0d | 09 72 65 74 75 72 6e 28 |tr(sp);.|.return(| |000022e0| 6c 70 29 3b 0d 09 0d 62 | 61 64 3a 0d 09 54 49 46 |lp);...b|ad:..TIF| |000022f0| 46 45 72 72 6f 72 28 74 | 69 2c 20 2d 31 2c 20 22 |FError(t|i, -1, "| |00002300| 5c 70 49 6e 76 61 6c 69 | 64 20 61 72 72 61 79 20 |\pInvali|d array | |00002310| 66 69 65 6c 64 2e 22 29 | 3b 0d 09 69 66 28 63 70 |field.")|;..if(cp| |00002320| 29 0d 09 09 44 69 73 70 | 6f 73 50 74 72 28 63 70 |)...Disp|osPtr(cp| |00002330| 29 3b 0d 09 69 66 28 73 | 70 29 0d 09 09 44 69 73 |);..if(s|p)...Dis| |00002340| 70 6f 73 50 74 72 28 73 | 70 29 3b 0d 09 69 66 28 |posPtr(s|p);..if(| |00002350| 6c 70 29 0d 09 09 44 69 | 73 70 6f 73 50 74 72 28 |lp)...Di|sposPtr(| |00002360| 6c 70 29 3b 0d 09 72 65 | 74 75 72 6e 28 30 29 3b |lp);..re|turn(0);| |00002370| 0d 7d 0d 0d 2f 2a 20 63 | 6f 6e 76 65 72 74 20 64 |.}../* c|onvert d| |00002380| 65 70 74 68 20 28 3c 3d | 20 38 29 20 74 6f 20 23 |epth (<=| 8) to #| |00002390| 20 6f 66 20 63 6f 6c 6f | 72 73 20 2a 2f 0d 69 6e | of colo|rs */.in| |000023a0| 74 20 43 6f 6c 6f 72 73 | 4f 66 44 65 70 74 68 5b |t Colors|OfDepth[| |000023b0| 5d 20 3d 20 7b 20 31 2c | 20 32 2c 20 34 2c 20 38 |] = { 1,| 2, 4, 8| |000023c0| 2c 20 31 36 2c 20 33 32 | 2c 20 36 34 2c 20 31 32 |, 16, 32|, 64, 12| |000023d0| 38 2c 20 32 35 36 20 7d | 3b 0d 0d 2f 2a 0d 20 2a |8, 256 }|;../*. *| |000023e0| 20 72 65 74 75 72 6e 20 | 61 20 63 6f 6c 6f 72 20 | return |a color | |000023f0| 6d 61 70 20 77 69 74 68 | 20 6e 67 72 61 79 73 20 |map with| ngrays | |00002400| 73 68 61 64 65 73 20 6f | 66 20 67 72 61 79 20 69 |shades o|f gray i| |00002410| 6e 20 69 74 2e 0d 20 2a | 2f 0d 43 54 61 62 48 61 |n it.. *|/.CTabHa| |00002420| 6e 64 6c 65 0d 4d 61 6b | 65 47 72 61 79 54 61 62 |ndle.Mak|eGrayTab| |00002430| 6c 65 28 69 6e 74 20 64 | 65 70 74 68 2c 20 69 6e |le(int d|epth, in| |00002440| 74 20 7a 65 72 6f 49 73 | 57 68 69 74 65 29 0d 7b |t zeroIs|White).{| |00002450| 0d 09 69 6e 74 20 69 2c | 20 6e 63 6f 6c 6f 72 73 |..int i,| ncolors| |00002460| 3b 0d 09 43 54 61 62 48 | 61 6e 64 6c 65 20 63 74 |;..CTabH|andle ct| |00002470| 68 3b 0d 09 52 47 42 43 | 6f 6c 6f 72 20 72 67 62 |h;..RGBC|olor rgb| |00002480| 3b 0d 09 0d 09 69 66 28 | 48 61 73 43 6f 6c 6f 72 |;....if(|HasColor| |00002490| 51 44 28 29 20 3d 3d 20 | 30 29 0d 09 09 72 65 74 |QD() == |0)...ret| |000024a0| 75 72 6e 28 30 29 3b 0d | 09 09 0d 09 69 66 28 64 |urn(0);.|....if(d| |000024b0| 65 70 74 68 20 3e 3d 20 | 31 20 26 26 20 64 65 70 |epth >= |1 && dep| |000024c0| 74 68 20 3c 3d 20 38 29 | 0d 09 09 6e 63 6f 6c 6f |th <= 8)|...ncolo| |000024d0| 72 73 20 3d 20 43 6f 6c | 6f 72 73 4f 66 44 65 70 |rs = Col|orsOfDep| |000024e0| 74 68 5b 64 65 70 74 68 | 5d 3b 0d 09 65 6c 73 65 |th[depth|];..else| |000024f0| 0d 09 09 72 65 74 75 72 | 6e 28 30 29 3b 0d 09 09 |...retur|n(0);...| |00002500| 0d 09 63 74 68 20 3d 20 | 28 43 54 61 62 48 61 6e |..cth = |(CTabHan| |00002510| 64 6c 65 29 20 4e 65 77 | 48 61 6e 64 6c 65 28 28 |dle) New|Handle((| |00002520| 6e 63 6f 6c 6f 72 73 20 | 2a 20 73 69 7a 65 6f 66 |ncolors |* sizeof| |00002530| 28 43 6f 6c 6f 72 53 70 | 65 63 29 29 20 2b 20 31 |(ColorSp|ec)) + 1| |00002540| 30 29 3b 0d 09 69 66 28 | 63 74 68 20 3d 3d 20 30 |0);..if(|cth == 0| |00002550| 29 0d 09 09 72 65 74 75 | 72 6e 28 30 29 3b 0d 09 |)...retu|rn(0);..| |00002560| 09 0d 09 28 2a 63 74 68 | 29 2d 3e 63 74 53 65 65 |...(*cth|)->ctSee| |00002570| 64 20 3d 20 47 65 74 43 | 54 53 65 65 64 28 29 3b |d = GetC|TSeed();| |00002580| 0d 09 28 2a 63 74 68 29 | 2d 3e 63 74 46 6c 61 67 |..(*cth)|->ctFlag| |00002590| 73 20 3d 20 30 3b 0d 09 | 28 2a 63 74 68 29 2d 3e |s = 0;..|(*cth)->| |000025a0| 63 74 53 69 7a 65 20 3d | 20 6e 63 6f 6c 6f 72 73 |ctSize =| ncolors| |000025b0| 20 2d 20 31 3b 0d 09 0d | 09 69 66 28 7a 65 72 6f | - 1;...|.if(zero| |000025c0| 49 73 57 68 69 74 65 29 | 7b 0d 09 09 66 6f 72 28 |IsWhite)|{...for(| |000025d0| 69 20 3d 20 30 3b 20 69 | 20 3c 20 6e 63 6f 6c 6f |i = 0; i| < ncolo| |000025e0| 72 73 3b 20 69 2b 2b 29 | 7b 0d 09 09 09 72 67 62 |rs; i++)|{....rgb| |000025f0| 2e 72 65 64 20 3d 20 72 | 67 62 2e 67 72 65 65 6e |.red = r|gb.green| |00002600| 20 3d 20 72 67 62 2e 62 | 6c 75 65 20 3d 20 28 36 | = rgb.b|lue = (6| |00002610| 35 35 33 35 20 2f 20 28 | 6e 63 6f 6c 6f 72 73 20 |5535 / (|ncolors | |00002620| 2d 20 31 29 29 20 2a 20 | 28 6e 63 6f 6c 6f 72 73 |- 1)) * |(ncolors| |00002630| 20 2d 20 69 20 2d 20 31 | 29 3b 0d 09 09 09 28 2a | - i - 1|);....(*| |00002640| 63 74 68 29 2d 3e 63 74 | 54 61 62 6c 65 5b 69 5d |cth)->ct|Table[i]| |00002650| 2e 76 61 6c 75 65 20 3d | 20 69 3b 20 2f 2a 20 74 |.value =| i; /* t| |00002660| 68 69 73 20 6d 75 73 74 | 20 62 65 20 66 69 6c 6c |his must| be fill| |00002670| 65 64 20 69 6e 2e 2e 2e | 20 2a 2f 0d 09 09 09 28 |ed in...| */....(| |00002680| 2a 63 74 68 29 2d 3e 63 | 74 54 61 62 6c 65 5b 69 |*cth)->c|tTable[i| |00002690| 5d 2e 72 67 62 20 3d 20 | 72 67 62 3b 0d 09 09 7d |].rgb = |rgb;...}| |000026a0| 0d 09 7d 20 65 6c 73 65 | 20 7b 0d 09 09 2f 2a 20 |..} else| {.../* | |000026b0| 74 68 69 73 20 64 6f 65 | 73 6e 27 74 20 77 6f 72 |this doe|sn't wor| |000026c0| 6b 20 73 6f 20 68 6f 74 | 20 6f 6e 20 74 68 65 20 |k so hot| on the | |000026d0| 4d 61 63 20 2a 2f 0d 09 | 09 66 6f 72 28 69 20 3d |Mac */..|.for(i =| |000026e0| 20 30 3b 20 69 20 3c 20 | 6e 63 6f 6c 6f 72 73 3b | 0; i < |ncolors;| |000026f0| 20 69 2b 2b 29 7b 0d 09 | 09 09 72 67 62 2e 72 65 | i++){..|..rgb.re| |00002700| 64 20 3d 20 72 67 62 2e | 67 72 65 65 6e 20 3d 20 |d = rgb.|green = | |00002710| 72 67 62 2e 62 6c 75 65 | 20 3d 20 28 36 35 35 33 |rgb.blue| = (6553| |00002720| 35 20 2f 20 28 6e 63 6f | 6c 6f 72 73 20 2d 20 31 |5 / (nco|lors - 1| |00002730| 29 29 20 2a 20 69 3b 0d | 09 09 09 28 2a 63 74 68 |)) * i;.|...(*cth| |00002740| 29 2d 3e 63 74 54 61 62 | 6c 65 5b 69 5d 2e 76 61 |)->ctTab|le[i].va| |00002750| 6c 75 65 20 3d 20 69 3b | 20 2f 2a 20 74 68 69 73 |lue = i;| /* this| |00002760| 20 6d 75 73 74 20 62 65 | 20 66 69 6c 6c 65 64 20 | must be| filled | |00002770| 69 6e 2e 2e 2e 20 2a 2f | 0d 09 09 09 28 2a 63 74 |in... */|....(*ct| |00002780| 68 29 2d 3e 63 74 54 61 | 62 6c 65 5b 69 5d 2e 72 |h)->ctTa|ble[i].r| |00002790| 67 62 20 3d 20 72 67 62 | 3b 0d 09 09 7d 0d 09 7d |gb = rgb|;...}..}| |000027a0| 0d 09 0d 09 72 65 74 75 | 72 6e 28 63 74 68 29 3b |....retu|rn(cth);| |000027b0| 0d 7d 0d 0d 2f 2a 0d 20 | 2a 20 54 75 72 6e 20 61 |.}../*. |* Turn a| |000027c0| 20 54 49 46 46 20 63 6f | 6c 6f 72 20 74 61 62 6c | TIFF co|lor tabl| |000027d0| 65 2c 20 77 68 69 63 68 | 20 68 61 73 20 72 65 64 |e, which| has red| |000027e0| 20 76 61 6c 75 65 73 2c | 20 74 68 65 6e 20 67 72 | values,| then gr| |000027f0| 65 65 6e 20 76 61 6c 75 | 65 73 2c 20 74 68 65 6e |een valu|es, then| |00002800| 20 62 6c 75 65 20 76 61 | 6c 75 65 73 2c 0d 20 2a | blue va|lues,. *| |00002810| 20 69 6e 74 6f 20 61 20 | 51 75 69 63 6b 44 72 61 | into a |QuickDra| |00002820| 77 20 43 6f 6c 6f 72 54 | 61 62 6c 65 2e 0d 20 2a |w ColorT|able.. *| |00002830| 2f 0d 43 54 61 62 48 61 | 6e 64 6c 65 0d 54 72 61 |/.CTabHa|ndle.Tra| |00002840| 6e 73 6c 61 74 65 43 6f | 6c 6f 72 4d 61 70 28 6c |nslateCo|lorMap(l| |00002850| 6f 6e 67 20 2a 63 6f 6c | 6f 72 4d 61 70 2c 20 69 |ong *col|orMap, i| |00002860| 6e 74 20 6e 63 6f 6c 6f | 72 73 29 0d 7b 0d 09 69 |nt ncolo|rs).{..i| |00002870| 6e 74 20 69 3b 0d 09 43 | 54 61 62 48 61 6e 64 6c |nt i;..C|TabHandl| |00002880| 65 20 63 74 68 3b 0d 09 | 52 47 42 43 6f 6c 6f 72 |e cth;..|RGBColor| |00002890| 20 72 67 62 3b 0d 09 0d | 09 69 66 28 48 61 73 43 | rgb;...|.if(HasC| |000028a0| 6f 6c 6f 72 51 44 28 29 | 20 3d 3d 20 30 29 0d 09 |olorQD()| == 0)..| |000028b0| 09 72 65 74 75 72 6e 28 | 30 29 3b 0d 09 09 0d 09 |.return(|0);.....| |000028c0| 69 66 28 63 6f 6c 6f 72 | 4d 61 70 20 3d 3d 20 30 |if(color|Map == 0| |000028d0| 20 7c 7c 20 6e 63 6f 6c | 6f 72 73 20 3c 3d 20 30 | || ncol|ors <= 0| |000028e0| 20 7c 7c 20 6e 63 6f 6c | 6f 72 73 20 3e 20 32 35 | || ncol|ors > 25| |000028f0| 36 29 0d 09 09 72 65 74 | 75 72 6e 28 30 29 3b 0d |6)...ret|urn(0);.| |00002900| 09 09 0d 09 63 74 68 20 | 3d 20 28 43 54 61 62 48 |....cth |= (CTabH| |00002910| 61 6e 64 6c 65 29 20 4e | 65 77 48 61 6e 64 6c 65 |andle) N|ewHandle| |00002920| 28 28 6e 63 6f 6c 6f 72 | 73 20 2a 20 73 69 7a 65 |((ncolor|s * size| |00002930| 6f 66 28 43 6f 6c 6f 72 | 53 70 65 63 29 29 20 2b |of(Color|Spec)) +| |00002940| 20 31 30 29 3b 0d 09 69 | 66 28 63 74 68 20 3d 3d | 10);..i|f(cth ==| |00002950| 20 30 29 0d 09 09 72 65 | 74 75 72 6e 28 30 29 3b | 0)...re|turn(0);| |00002960| 0d 09 09 0d 09 28 2a 63 | 74 68 29 2d 3e 63 74 53 |.....(*c|th)->ctS| |00002970| 65 65 64 20 3d 20 47 65 | 74 43 54 53 65 65 64 28 |eed = Ge|tCTSeed(| |00002980| 29 3b 0d 09 28 2a 63 74 | 68 29 2d 3e 63 74 46 6c |);..(*ct|h)->ctFl| |00002990| 61 67 73 20 3d 20 30 3b | 0d 09 28 2a 63 74 68 29 |ags = 0;|..(*cth)| |000029a0| 2d 3e 63 74 53 69 7a 65 | 20 3d 20 6e 63 6f 6c 6f |->ctSize| = ncolo| |000029b0| 72 73 20 2d 20 31 3b 0d | 09 0d 09 66 6f 72 28 69 |rs - 1;.|...for(i| |000029c0| 20 3d 20 30 3b 20 69 20 | 3c 20 6e 63 6f 6c 6f 72 | = 0; i |< ncolor| |000029d0| 73 3b 20 69 2b 2b 29 7b | 0d 09 09 72 67 62 2e 72 |s; i++){|...rgb.r| |000029e0| 65 64 20 3d 20 63 6f 6c | 6f 72 4d 61 70 5b 69 5d |ed = col|orMap[i]| |000029f0| 3b 0d 09 09 72 67 62 2e | 67 72 65 65 6e 20 3d 20 |;...rgb.|green = | |00002a00| 63 6f 6c 6f 72 4d 61 70 | 5b 69 20 2b 20 6e 63 6f |colorMap|[i + nco| |00002a10| 6c 6f 72 73 5d 3b 0d 09 | 09 72 67 62 2e 62 6c 75 |lors];..|.rgb.blu| |00002a20| 65 20 3d 20 63 6f 6c 6f | 72 4d 61 70 5b 69 20 2b |e = colo|rMap[i +| |00002a30| 20 6e 63 6f 6c 6f 72 73 | 20 2b 20 6e 63 6f 6c 6f | ncolors| + ncolo| |00002a40| 72 73 5d 3b 0d 09 09 28 | 2a 63 74 68 29 2d 3e 63 |rs];...(|*cth)->c| |00002a50| 74 54 61 62 6c 65 5b 69 | 5d 2e 76 61 6c 75 65 20 |tTable[i|].value | |00002a60| 3d 20 69 3b 20 2f 2a 20 | 74 68 69 73 20 6d 75 73 |= i; /* |this mus| |00002a70| 74 20 62 65 20 66 69 6c | 6c 65 64 20 69 6e 2e 2e |t be fil|led in..| |00002a80| 2e 20 2a 2f 0d 09 09 28 | 2a 63 74 68 29 2d 3e 63 |. */...(|*cth)->c| |00002a90| 74 54 61 62 6c 65 5b 69 | 5d 2e 72 67 62 20 3d 20 |tTable[i|].rgb = | |00002aa0| 72 67 62 3b 0d 09 7d 0d | 09 0d 09 72 65 74 75 72 |rgb;..}.|...retur| |00002ab0| 6e 28 63 74 68 29 3b 0d | 0d 7d 0d 0d 6c 6f 6e 67 |n(cth);.|.}..long| |00002ac0| 0d 74 74 6f 68 73 28 54 | 49 46 46 50 74 72 20 74 |.ttohs(T|IFFPtr t| |00002ad0| 69 2c 20 73 68 6f 72 74 | 20 73 29 0d 7b 0d 09 6c |i, short| s).{..l| |00002ae0| 6f 6e 67 20 73 31 3b 0d | 09 0d 09 69 66 28 74 69 |ong s1;.|...if(ti| |00002af0| 2d 3e 62 79 74 65 4f 72 | 64 65 72 20 3d 3d 20 42 |->byteOr|der == B| |00002b00| 69 67 45 6e 64 69 61 6e | 29 7b 0d 09 09 2f 2a 20 |igEndian|){.../* | |00002b10| 4d 61 63 2d 6f 72 64 65 | 72 20 2a 2f 0d 09 09 72 |Mac-orde|r */...r| |00002b20| 65 74 75 72 6e 28 73 20 | 26 20 30 78 66 66 66 66 |eturn(s |& 0xffff| |00002b30| 29 3b 0d 09 7d 20 65 6c | 73 65 20 7b 0d 09 09 73 |);..} el|se {...s| |00002b40| 31 20 3d 20 28 73 20 3e | 3e 20 38 29 20 26 20 30 |1 = (s >|> 8) & 0| |00002b50| 78 66 66 3b 0d 09 09 73 | 31 20 7c 3d 20 28 73 20 |xff;...s|1 |= (s | |00002b60| 26 20 30 78 66 66 29 20 | 3c 3c 20 38 3b 0d 09 09 |& 0xff) |<< 8;...| |00002b70| 72 65 74 75 72 6e 28 73 | 31 29 3b 0d 09 7d 0d 7d |return(s|1);..}.}| |00002b80| 0d 0d 6c 6f 6e 67 0d 74 | 74 6f 68 6c 28 54 49 46 |..long.t|tohl(TIF| |00002b90| 46 50 74 72 20 74 69 2c | 20 6c 6f 6e 67 20 6c 29 |FPtr ti,| long l)| |00002ba0| 0d 7b 0d 09 6c 6f 6e 67 | 20 6c 31 3b 0d 09 69 6e |.{..long| l1;..in| |00002bb0| 74 20 69 3b 0d 09 0d 09 | 69 66 28 74 69 2d 3e 62 |t i;....|if(ti->b| |00002bc0| 79 74 65 4f 72 64 65 72 | 20 3d 3d 20 42 69 67 45 |yteOrder| == BigE| |00002bd0| 6e 64 69 61 6e 29 7b 0d | 09 09 2f 2a 20 4d 61 63 |ndian){.|../* Mac| |00002be0| 2d 6f 72 64 65 72 20 2a | 2f 0d 09 09 72 65 74 75 |-order *|/...retu| |00002bf0| 72 6e 28 6c 29 3b 0d 09 | 7d 20 65 6c 73 65 20 7b |rn(l);..|} else {| |00002c00| 0d 09 09 6c 31 20 3d 20 | 30 3b 0d 09 09 66 6f 72 |...l1 = |0;...for| |00002c10| 28 69 20 3d 20 30 3b 20 | 69 20 3c 20 34 3b 20 69 |(i = 0; |i < 4; i| |00002c20| 2b 2b 29 7b 0d 09 09 09 | 6c 31 20 3c 3c 3d 20 38 |++){....|l1 <<= 8| |00002c30| 3b 0d 09 09 09 6c 31 20 | 7c 3d 20 28 6c 20 26 20 |;....l1 ||= (l & | |00002c40| 30 78 66 66 29 3b 0d 09 | 09 09 6c 20 3e 3e 3d 20 |0xff);..|..l >>= | |00002c50| 38 3b 0d 09 09 7d 0d 09 | 09 72 65 74 75 72 6e 28 |8;...}..|.return(| |00002c60| 6c 31 29 3b 0d 09 7d 0d | 7d 0d 0d 4f 53 45 72 72 |l1);..}.|}..OSErr| |00002c70| 0d 74 69 66 66 5f 72 65 | 61 64 28 54 49 46 46 50 |.tiff_re|ad(TIFFP| |00002c80| 74 72 20 74 69 2c 20 75 | 6e 73 69 67 6e 65 64 20 |tr ti, u|nsigned | |00002c90| 6c 6f 6e 67 20 6f 66 66 | 73 65 74 2c 20 76 6f 69 |long off|set, voi| |00002ca0| 64 20 2a 62 75 66 2c 20 | 6c 6f 6e 67 20 6e 29 0d |d *buf, |long n).| |00002cb0| 7b 0d 09 69 6e 74 20 65 | 72 72 3b 0d 09 6c 6f 6e |{..int e|rr;..lon| |00002cc0| 67 20 63 6f 75 6e 74 3b | 0d 09 0d 09 65 72 72 20 |g count;|....err | |00002cd0| 3d 20 53 65 74 46 50 6f | 73 28 74 69 2d 3e 72 65 |= SetFPo|s(ti->re| |00002ce0| 66 2c 20 66 73 46 72 6f | 6d 53 74 61 72 74 2c 20 |f, fsFro|mStart, | |00002cf0| 6f 66 66 73 65 74 29 3b | 0d 09 69 66 28 65 72 72 |offset);|..if(err| |00002d00| 20 3c 20 30 29 7b 0d 09 | 09 54 49 46 46 45 72 72 | < 0){..|.TIFFErr| |00002d10| 6f 72 28 74 69 2c 20 65 | 72 72 2c 20 22 5c 70 53 |or(ti, e|rr, "\pS| |00002d20| 65 65 6b 20 66 61 69 6c | 65 64 2e 22 29 3b 0d 09 |eek fail|ed.");..| |00002d30| 09 72 65 74 75 72 6e 28 | 65 72 72 29 3b 0d 09 7d |.return(|err);..}| |00002d40| 0d 09 09 0d 09 63 6f 75 | 6e 74 20 3d 20 6e 3b 0d |.....cou|nt = n;.| |00002d50| 09 65 72 72 20 3d 20 46 | 53 52 65 61 64 28 74 69 |.err = F|SRead(ti| |00002d60| 2d 3e 72 65 66 2c 20 26 | 63 6f 75 6e 74 2c 20 62 |->ref, &|count, b| |00002d70| 75 66 29 3b 0d 09 69 66 | 28 65 72 72 20 3c 20 30 |uf);..if|(err < 0| |00002d80| 20 26 26 20 65 72 72 20 | 21 3d 20 65 6f 66 45 72 | && err |!= eofEr| |00002d90| 72 29 7b 0d 09 09 54 49 | 46 46 45 72 72 6f 72 28 |r){...TI|FFError(| |00002da0| 74 69 2c 20 65 72 72 2c | 20 22 5c 70 52 65 61 64 |ti, err,| "\pRead| |00002db0| 20 66 61 69 6c 65 64 2e | 22 29 3b 0d 09 09 72 65 | failed.|");...re| |00002dc0| 74 75 72 6e 28 65 72 72 | 29 3b 0d 09 7d 0d 09 69 |turn(err|);..}..i| |00002dd0| 66 28 63 6f 75 6e 74 20 | 21 3d 20 6e 29 7b 0d 09 |f(count |!= n){..| |00002de0| 09 54 49 46 46 45 72 72 | 6f 72 28 74 69 2c 20 2d |.TIFFErr|or(ti, -| |00002df0| 31 2c 20 22 5c 70 52 65 | 61 64 20 72 65 74 75 72 |1, "\pRe|ad retur| |00002e00| 6e 65 64 20 74 6f 6f 20 | 6c 69 74 74 6c 65 20 64 |ned too |little d| |00002e10| 61 74 61 2e 22 29 3b 0d | 09 09 72 65 74 75 72 6e |ata.");.|..return| |00002e20| 28 65 6f 66 45 72 72 29 | 3b 0d 09 7d 0d 09 09 0d |(eofErr)|;..}....| |00002e30| 09 72 65 74 75 72 6e 28 | 30 29 3b 0d 7d 0d 0d 50 |.return(|0);.}..P| |00002e40| 69 78 4d 61 70 48 61 6e | 64 6c 65 0d 50 61 6c 65 |ixMapHan|dle.Pale| |00002e50| 74 74 65 50 69 78 4d 61 | 70 28 73 68 6f 72 74 20 |ttePixMa|p(short | |00002e60| 64 65 70 74 68 2c 20 43 | 54 61 62 48 61 6e 64 6c |depth, C|TabHandl| |00002e70| 65 20 63 74 68 2c 20 6c | 6f 6e 67 20 78 2c 20 6c |e cth, l|ong x, l| |00002e80| 6f 6e 67 20 79 2c 20 6c | 6f 6e 67 20 77 69 64 74 |ong y, l|ong widt| |00002e90| 68 2c 20 6c 6f 6e 67 20 | 68 65 69 67 68 74 2c 0d |h, long |height,.| |00002ea0| 09 09 09 20 20 50 74 72 | 20 64 61 74 61 2c 20 6c |... Ptr| data, l| |00002eb0| 6f 6e 67 20 72 6f 77 29 | 0d 7b 0d 09 50 69 78 4d |ong row)|.{..PixM| |00002ec0| 61 70 48 61 6e 64 6c 65 | 20 70 6d 3b 0d 09 0d 09 |apHandle| pm;....| |00002ed0| 69 66 28 48 61 73 43 6f | 6c 6f 72 51 44 28 29 20 |if(HasCo|lorQD() | |00002ee0| 3d 3d 20 30 29 0d 09 09 | 72 65 74 75 72 6e 28 30 |== 0)...|return(0| |00002ef0| 29 3b 0d 09 09 0d 09 2f | 2a 20 45 6e 66 6f 72 63 |);...../|* Enforc| |00002f00| 65 20 72 65 73 74 72 69 | 63 74 69 6f 6e 73 2e 20 |e restri|ctions. | |00002f10| 2a 2f 0d 09 69 66 28 28 | 72 6f 77 20 26 20 31 29 |*/..if((|row & 1)| |00002f20| 20 21 3d 20 30 20 7c 7c | 0d 09 20 20 20 28 28 28 | != 0 |||.. (((| |00002f30| 6c 6f 6e 67 29 20 64 61 | 74 61 29 20 26 20 31 29 |long) da|ta) & 1)| |00002f40| 20 21 3d 20 30 20 7c 7c | 0d 09 20 20 20 28 64 65 | != 0 |||.. (de| |00002f50| 70 74 68 20 21 3d 20 31 | 20 26 26 20 64 65 70 74 |pth != 1| && dept| |00002f60| 68 20 21 3d 20 32 20 26 | 26 20 64 65 70 74 68 20 |h != 2 &|& depth | |00002f70| 21 3d 20 34 20 26 26 20 | 64 65 70 74 68 20 21 3d |!= 4 && |depth !=| |00002f80| 20 38 29 20 7c 7c 0d 09 | 20 20 20 63 74 68 20 3d | 8) ||..| cth =| |00002f90| 3d 20 30 29 7b 0d 09 20 | 20 20 09 72 65 74 75 72 |= 0){.. | .retur| |00002fa0| 6e 28 30 29 3b 0d 09 7d | 0d 09 0d 09 70 6d 20 3d |n(0);..}|....pm =| |00002fb0| 20 4e 65 77 50 69 78 4d | 61 70 28 29 3b 0d 09 69 | NewPixM|ap();..i| |00002fc0| 66 28 70 6d 20 3d 3d 20 | 30 29 0d 09 09 72 65 74 |f(pm == |0)...ret| |00002fd0| 75 72 6e 28 30 29 3b 0d | 09 09 0d 09 28 2a 70 6d |urn(0);.|....(*pm| |00002fe0| 29 2d 3e 70 6d 56 65 72 | 73 69 6f 6e 20 3d 20 30 |)->pmVer|sion = 0| |00002ff0| 3b 20 2f 2a 20 74 68 69 | 73 20 69 73 20 63 72 75 |; /* thi|s is cru| |00003000| 63 69 61 6c 20 2a 2f 0d | 09 28 2a 70 6d 29 2d 3e |cial */.|.(*pm)->| |00003010| 70 6d 52 65 73 65 72 76 | 65 64 20 3d 20 30 3b 0d |pmReserv|ed = 0;.| |00003020| 09 28 2a 70 6d 29 2d 3e | 70 61 63 6b 54 79 70 65 |.(*pm)->|packType| |00003030| 20 3d 20 30 3b 0d 09 28 | 2a 70 6d 29 2d 3e 70 61 | = 0;..(|*pm)->pa| |00003040| 63 6b 53 69 7a 65 20 3d | 20 30 3b 0d 09 28 2a 70 |ckSize =| 0;..(*p| |00003050| 6d 29 2d 3e 70 69 78 65 | 6c 54 79 70 65 20 3d 20 |m)->pixe|lType = | |00003060| 30 3b 20 2f 2a 20 63 68 | 75 6e 6b 79 20 2a 2f 0d |0; /* ch|unky */.| |00003070| 09 28 2a 70 6d 29 2d 3e | 70 69 78 65 6c 53 69 7a |.(*pm)->|pixelSiz| |00003080| 65 20 3d 20 64 65 70 74 | 68 3b 20 2f 2a 20 62 69 |e = dept|h; /* bi| |00003090| 74 73 20 70 65 72 20 70 | 69 78 65 6c 20 2a 2f 0d |ts per p|ixel */.| |000030a0| 09 28 2a 70 6d 29 2d 3e | 63 6d 70 43 6f 75 6e 74 |.(*pm)->|cmpCount| |000030b0| 20 3d 20 31 3b 20 2f 2a | 20 31 20 63 6f 6d 70 6f | = 1; /*| 1 compo| |000030c0| 6e 65 6e 74 20 70 65 72 | 20 70 69 78 65 6c 20 2a |nent per| pixel *| |000030d0| 2f 0d 09 28 2a 70 6d 29 | 2d 3e 63 6d 70 53 69 7a |/..(*pm)|->cmpSiz| |000030e0| 65 20 3d 20 64 65 70 74 | 68 3b 20 2f 2a 20 62 69 |e = dept|h; /* bi| |000030f0| 74 73 20 70 65 72 20 63 | 6f 6d 70 6f 6e 65 6e 74 |ts per c|omponent| |00003100| 20 2a 2f 0d 09 28 2a 70 | 6d 29 2d 3e 70 6c 61 6e | */..(*p|m)->plan| |00003110| 65 42 79 74 65 73 20 3d | 20 30 3b 0d 09 0d 09 28 |eBytes =| 0;....(| |00003120| 2a 70 6d 29 2d 3e 62 6f | 75 6e 64 73 2e 6c 65 66 |*pm)->bo|unds.lef| |00003130| 74 20 3d 20 78 3b 0d 09 | 28 2a 70 6d 29 2d 3e 62 |t = x;..|(*pm)->b| |00003140| 6f 75 6e 64 73 2e 72 69 | 67 68 74 20 3d 20 78 20 |ounds.ri|ght = x | |00003150| 2b 20 77 69 64 74 68 3b | 0d 09 28 2a 70 6d 29 2d |+ width;|..(*pm)-| |00003160| 3e 62 6f 75 6e 64 73 2e | 74 6f 70 20 3d 20 79 3b |>bounds.|top = y;| |00003170| 0d 09 28 2a 70 6d 29 2d | 3e 62 6f 75 6e 64 73 2e |..(*pm)-|>bounds.| |00003180| 62 6f 74 74 6f 6d 20 3d | 20 79 20 2b 20 68 65 69 |bottom =| y + hei| |00003190| 67 68 74 3b 0d 09 0d 09 | 28 2a 70 6d 29 2d 3e 62 |ght;....|(*pm)->b| |000031a0| 61 73 65 41 64 64 72 20 | 3d 20 64 61 74 61 3b 0d |aseAddr |= data;.| |000031b0| 09 28 2a 70 6d 29 2d 3e | 72 6f 77 42 79 74 65 73 |.(*pm)->|rowBytes| |000031c0| 20 3d 20 72 6f 77 20 7c | 20 30 78 38 30 30 30 3b | = row || 0x8000;| |000031d0| 20 2f 2a 20 74 68 65 20 | 30 78 38 30 30 30 20 6d | /* the |0x8000 m| |000031e0| 61 72 6b 73 20 74 68 69 | 73 20 61 73 20 61 20 50 |arks thi|s as a P| |000031f0| 69 78 6d 61 70 2c 20 6e | 6f 74 20 42 69 74 6d 61 |ixmap, n|ot Bitma| |00003200| 70 20 2a 2f 0d 09 0d 09 | 69 66 28 28 2a 70 6d 29 |p */....|if((*pm)| |00003210| 2d 3e 70 6d 54 61 62 6c | 65 20 3d 3d 20 30 29 7b |->pmTabl|e == 0){| |00003220| 0d 09 09 44 69 73 70 6f | 73 50 69 78 4d 61 70 28 |...Dispo|sPixMap(| |00003230| 70 6d 29 3b 0d 09 09 72 | 65 74 75 72 6e 28 30 29 |pm);...r|eturn(0)| |00003240| 3b 0d 09 7d 0d 09 09 0d | 09 2f 2a 0d 09 20 2a 20 |;..}....|./*.. * | |00003250| 47 69 76 65 20 74 68 65 | 20 50 69 78 4d 61 70 20 |Give the| PixMap | |00003260| 69 74 73 20 6f 77 6e 20 | 63 6f 6c 6f 72 20 74 61 |its own |color ta| |00003270| 62 6c 65 2c 20 77 68 69 | 63 68 20 44 69 73 70 6f |ble, whi|ch Dispo| |00003280| 73 50 69 78 4d 61 70 28 | 29 20 66 72 65 65 73 2e |sPixMap(|) frees.| |00003290| 0d 09 20 2a 2f 0d 09 4d | 6f 76 65 48 48 69 28 63 |.. */..M|oveHHi(c| |000032a0| 74 68 29 3b 0d 09 48 4c | 6f 63 6b 28 63 74 68 29 |th);..HL|ock(cth)| |000032b0| 3b 0d 09 50 74 72 54 6f | 58 48 61 6e 64 28 2a 63 |;..PtrTo|XHand(*c| |000032c0| 74 68 2c 20 28 2a 70 6d | 29 2d 3e 70 6d 54 61 62 |th, (*pm|)->pmTab| |000032d0| 6c 65 2c 20 47 65 74 48 | 61 6e 64 6c 65 53 69 7a |le, GetH|andleSiz| |000032e0| 65 28 63 74 68 29 29 3b | 0d 09 48 55 6e 6c 6f 63 |e(cth));|..HUnloc| |000032f0| 6b 28 63 74 68 29 3b 0d | 09 0d 09 72 65 74 75 72 |k(cth);.|...retur| |00003300| 6e 28 70 6d 29 3b 0d 7d | 0d 0d 50 69 78 4d 61 70 |n(pm);.}|..PixMap| |00003310| 48 61 6e 64 6c 65 0d 52 | 47 42 50 69 78 4d 61 70 |Handle.R|GBPixMap| |00003320| 28 73 68 6f 72 74 20 64 | 65 70 74 68 2c 20 6c 6f |(short d|epth, lo| |00003330| 6e 67 20 78 2c 20 6c 6f | 6e 67 20 79 2c 20 6c 6f |ng x, lo|ng y, lo| |00003340| 6e 67 20 77 69 64 74 68 | 2c 20 6c 6f 6e 67 20 68 |ng width|, long h| |00003350| 65 69 67 68 74 2c 0d 09 | 09 20 20 50 74 72 20 64 |eight,..|. Ptr d| |00003360| 61 74 61 2c 20 6c 6f 6e | 67 20 72 6f 77 62 79 74 |ata, lon|g rowbyt| |00003370| 65 73 29 0d 7b 0d 09 50 | 69 78 4d 61 70 48 61 6e |es).{..P|ixMapHan| |00003380| 64 6c 65 20 70 6d 3b 0d | 09 0d 09 69 66 28 48 61 |dle pm;.|...if(Ha| |00003390| 73 51 44 33 32 28 29 20 | 3d 3d 20 30 29 0d 09 09 |sQD32() |== 0)...| |000033a0| 72 65 74 75 72 6e 28 30 | 29 3b 0d 09 09 0d 09 2f |return(0|);...../| |000033b0| 2a 20 45 6e 66 6f 72 63 | 65 20 72 65 73 74 72 69 |* Enforc|e restri| |000033c0| 63 74 69 6f 6e 73 2e 20 | 2a 2f 0d 09 69 66 28 28 |ctions. |*/..if((| |000033d0| 72 6f 77 62 79 74 65 73 | 20 26 20 31 29 20 21 3d |rowbytes| & 1) !=| |000033e0| 20 30 20 7c 7c 0d 09 20 | 20 20 28 28 28 6c 6f 6e | 0 ||.. | (((lon| |000033f0| 67 29 20 64 61 74 61 29 | 20 26 20 31 29 20 21 3d |g) data)| & 1) !=| |00003400| 20 30 20 7c 7c 0d 09 20 | 20 20 28 64 65 70 74 68 | 0 ||.. | (depth| |00003410| 20 21 3d 20 31 36 20 26 | 26 20 64 65 70 74 68 20 | != 16 &|& depth | |00003420| 21 3d 20 33 32 29 29 7b | 0d 09 20 20 20 09 72 65 |!= 32)){|.. .re| |00003430| 74 75 72 6e 28 30 29 3b | 0d 09 7d 0d 09 0d 09 70 |turn(0);|..}....p| |00003440| 6d 20 3d 20 4e 65 77 50 | 69 78 4d 61 70 28 29 3b |m = NewP|ixMap();| |00003450| 0d 09 69 66 28 70 6d 20 | 3d 3d 20 30 29 0d 09 09 |..if(pm |== 0)...| |00003460| 72 65 74 75 72 6e 28 30 | 29 3b 0d 09 09 0d 09 28 |return(0|);.....(| |00003470| 2a 70 6d 29 2d 3e 70 6d | 56 65 72 73 69 6f 6e 20 |*pm)->pm|Version | |00003480| 3d 20 30 3b 20 2f 2a 20 | 74 68 69 73 20 69 73 20 |= 0; /* |this is | |00003490| 63 72 75 63 69 61 6c 20 | 2a 2f 0d 09 28 2a 70 6d |crucial |*/..(*pm| |000034a0| 29 2d 3e 70 6d 52 65 73 | 65 72 76 65 64 20 3d 20 |)->pmRes|erved = | |000034b0| 30 3b 0d 09 28 2a 70 6d | 29 2d 3e 70 61 63 6b 54 |0;..(*pm|)->packT| |000034c0| 79 70 65 20 3d 20 30 3b | 0d 09 28 2a 70 6d 29 2d |ype = 0;|..(*pm)-| |000034d0| 3e 70 61 63 6b 53 69 7a | 65 20 3d 20 30 3b 0d 09 |>packSiz|e = 0;..| |000034e0| 28 2a 70 6d 29 2d 3e 70 | 69 78 65 6c 54 79 70 65 |(*pm)->p|ixelType| |000034f0| 20 3d 20 31 36 3b 20 2f | 2a 20 52 47 42 44 69 72 | = 16; /|* RGBDir| |00003500| 65 63 74 20 2a 2f 0d 09 | 28 2a 70 6d 29 2d 3e 70 |ect */..|(*pm)->p| |00003510| 69 78 65 6c 53 69 7a 65 | 20 3d 20 64 65 70 74 68 |ixelSize| = depth| |00003520| 3b 20 2f 2a 20 62 69 74 | 73 20 70 65 72 20 70 69 |; /* bit|s per pi| |00003530| 78 65 6c 20 2a 2f 0d 09 | 28 2a 70 6d 29 2d 3e 63 |xel */..|(*pm)->c| |00003540| 6d 70 43 6f 75 6e 74 20 | 3d 20 33 3b 20 2f 2a 20 |mpCount |= 3; /* | |00003550| 31 20 63 6f 6d 70 6f 6e | 65 6e 74 20 70 65 72 20 |1 compon|ent per | |00003560| 70 69 78 65 6c 20 2a 2f | 0d 09 28 2a 70 6d 29 2d |pixel */|..(*pm)-| |00003570| 3e 63 6d 70 53 69 7a 65 | 20 3d 20 28 64 65 70 74 |>cmpSize| = (dept| |00003580| 68 20 3d 3d 20 33 32 20 | 3f 20 38 20 3a 20 35 29 |h == 32 |? 8 : 5)| |00003590| 3b 20 2f 2a 20 62 69 74 | 73 20 70 65 72 20 63 6f |; /* bit|s per co| |000035a0| 6d 70 6f 6e 65 6e 74 20 | 2a 2f 0d 09 28 2a 70 6d |mponent |*/..(*pm| |000035b0| 29 2d 3e 70 6c 61 6e 65 | 42 79 74 65 73 20 3d 20 |)->plane|Bytes = | |000035c0| 30 3b 0d 09 0d 09 28 2a | 70 6d 29 2d 3e 62 6f 75 |0;....(*|pm)->bou| |000035d0| 6e 64 73 2e 6c 65 66 74 | 20 3d 20 78 3b 0d 09 28 |nds.left| = x;..(| |000035e0| 2a 70 6d 29 2d 3e 62 6f | 75 6e 64 73 2e 72 69 67 |*pm)->bo|unds.rig| |000035f0| 68 74 20 3d 20 78 20 2b | 20 77 69 64 74 68 3b 0d |ht = x +| width;.| |00003600| 09 28 2a 70 6d 29 2d 3e | 62 6f 75 6e 64 73 2e 74 |.(*pm)->|bounds.t| |00003610| 6f 70 20 3d 20 79 3b 0d | 09 28 2a 70 6d 29 2d 3e |op = y;.|.(*pm)->| |00003620| 62 6f 75 6e 64 73 2e 62 | 6f 74 74 6f 6d 20 3d 20 |bounds.b|ottom = | |00003630| 79 20 2b 20 68 65 69 67 | 68 74 3b 0d 09 0d 09 28 |y + heig|ht;....(| |00003640| 2a 70 6d 29 2d 3e 62 61 | 73 65 41 64 64 72 20 3d |*pm)->ba|seAddr =| |00003650| 20 64 61 74 61 3b 0d 09 | 28 2a 70 6d 29 2d 3e 72 | data;..|(*pm)->r| |00003660| 6f 77 42 79 74 65 73 20 | 3d 20 72 6f 77 62 79 74 |owBytes |= rowbyt| |00003670| 65 73 20 7c 20 30 78 38 | 30 30 30 3b 20 2f 2a 20 |es | 0x8|000; /* | |00003680| 74 68 65 20 30 78 38 30 | 30 30 20 6d 61 72 6b 73 |the 0x80|00 marks| |00003690| 20 74 68 69 73 20 61 73 | 20 61 20 50 69 78 6d 61 | this as| a Pixma| |000036a0| 70 2c 20 6e 6f 74 20 42 | 69 74 6d 61 70 20 2a 2f |p, not B|itmap */| |000036b0| 0d 09 0d 09 72 65 74 75 | 72 6e 28 70 6d 29 3b 0d |....retu|rn(pm);.| |000036c0| 7d 0d 0d 2f 2a 0d 20 2a | 20 52 65 74 75 72 6e 20 |}../*. *| Return | |000036d0| 28 61 2a 62 29 2f 63 2e | 20 54 72 79 20 74 6f 20 |(a*b)/c.| Try to | |000036e0| 6d 69 6e 69 6d 69 7a 65 | 20 74 68 65 20 65 72 72 |minimize| the err| |000036f0| 6f 72 2e 0d 20 2a 2f 0d | 23 64 65 66 69 6e 65 20 |or.. */.|#define | |00003700| 4d 75 6c 44 69 76 28 61 | 2c 20 62 2c 20 63 29 20 |MulDiv(a|, b, c) | |00003710| 28 28 28 61 29 20 2a 20 | 28 62 29 29 20 2f 20 28 |(((a) * |(b)) / (| |00003720| 63 29 29 0d 0d 2f 2a 0d | 20 2a 20 43 6f 6e 76 65 |c))../*.| * Conve| |00003730| 72 74 20 61 20 66 72 6f | 6d 20 63 6f 6f 72 64 69 |rt a fro|m coordi| |00003740| 6e 61 74 65 20 77 6f 72 | 6c 64 20 61 72 65 66 20 |nate wor|ld aref | |00003750| 74 6f 20 77 6f 72 6c 64 | 20 62 72 65 66 2e 20 52 |to world| bref. R| |00003760| 65 73 75 6c 74 20 69 6e | 20 62 2e 0d 20 2a 20 4f |esult in| b.. * O| |00003770| 70 74 69 6d 69 7a 65 64 | 20 66 6f 72 20 61 72 65 |ptimized| for are| |00003780| 66 20 61 6e 64 20 62 72 | 65 66 20 74 68 65 20 73 |f and br|ef the s| |00003790| 61 6d 65 20 73 69 7a 65 | 2e 0d 20 2a 2f 0d 76 6f |ame size|.. */.vo| |000037a0| 69 64 0d 53 63 61 6c 65 | 52 65 63 74 28 52 65 63 |id.Scale|Rect(Rec| |000037b0| 74 20 2a 61 72 65 66 2c | 20 52 65 63 74 20 2a 61 |t *aref,| Rect *a| |000037c0| 2c 20 52 65 63 74 20 2a | 62 72 65 66 2c 20 52 65 |, Rect *|bref, Re| |000037d0| 63 74 20 2a 62 29 0d 7b | 0d 09 6c 6f 6e 67 20 68 |ct *b).{|..long h| |000037e0| 6d 75 6c 2c 20 68 64 69 | 76 2c 20 68 6f 66 66 3b |mul, hdi|v, hoff;| |000037f0| 0d 09 6c 6f 6e 67 20 76 | 6d 75 6c 2c 20 76 64 69 |..long v|mul, vdi| |00003800| 76 2c 20 76 6f 66 66 3b | 0d 09 0d 09 68 6d 75 6c |v, voff;|....hmul| |00003810| 20 3d 20 62 72 65 66 2d | 3e 72 69 67 68 74 20 2d | = bref-|>right -| |00003820| 20 62 72 65 66 2d 3e 6c | 65 66 74 3b 0d 09 68 64 | bref->l|eft;..hd| |00003830| 69 76 20 3d 20 61 72 65 | 66 2d 3e 72 69 67 68 74 |iv = are|f->right| |00003840| 20 2d 20 61 72 65 66 2d | 3e 6c 65 66 74 3b 0d 09 | - aref-|>left;..| |00003850| 0d 09 68 6f 66 66 20 3d | 20 62 72 65 66 2d 3e 6c |..hoff =| bref->l| |00003860| 65 66 74 20 2d 20 4d 75 | 6c 44 69 76 28 61 72 65 |eft - Mu|lDiv(are| |00003870| 66 2d 3e 6c 65 66 74 2c | 20 68 6d 75 6c 2c 20 68 |f->left,| hmul, h| |00003880| 64 69 76 29 3b 0d 09 0d | 09 76 6d 75 6c 20 3d 20 |div);...|.vmul = | |00003890| 62 72 65 66 2d 3e 62 6f | 74 74 6f 6d 20 2d 20 62 |bref->bo|ttom - b| |000038a0| 72 65 66 2d 3e 74 6f 70 | 3b 0d 09 76 64 69 76 20 |ref->top|;..vdiv | |000038b0| 3d 20 61 72 65 66 2d 3e | 62 6f 74 74 6f 6d 20 2d |= aref->|bottom -| |000038c0| 20 61 72 65 66 2d 3e 74 | 6f 70 3b 0d 09 0d 09 76 | aref->t|op;....v| |000038d0| 6f 66 66 20 3d 20 62 72 | 65 66 2d 3e 74 6f 70 20 |off = br|ef->top | |000038e0| 2d 20 4d 75 6c 44 69 76 | 28 61 72 65 66 2d 3e 74 |- MulDiv|(aref->t| |000038f0| 6f 70 2c 20 76 6d 75 6c | 2c 20 76 64 69 76 29 3b |op, vmul|, vdiv);| |00003900| 0d 09 0d 09 62 2d 3e 6c | 65 66 74 20 3d 20 4d 75 |....b->l|eft = Mu| |00003910| 6c 44 69 76 28 61 2d 3e | 6c 65 66 74 2c 20 68 6d |lDiv(a->|left, hm| |00003920| 75 6c 2c 20 68 64 69 76 | 29 20 2b 20 68 6f 66 66 |ul, hdiv|) + hoff| |00003930| 3b 0d 09 62 2d 3e 72 69 | 67 68 74 20 3d 20 4d 75 |;..b->ri|ght = Mu| |00003940| 6c 44 69 76 28 61 2d 3e | 72 69 67 68 74 2c 20 68 |lDiv(a->|right, h| |00003950| 6d 75 6c 2c 20 68 64 69 | 76 29 20 2b 20 68 6f 66 |mul, hdi|v) + hof| |00003960| 66 3b 0d 09 62 2d 3e 74 | 6f 70 20 3d 20 4d 75 6c |f;..b->t|op = Mul| |00003970| 44 69 76 28 61 2d 3e 74 | 6f 70 2c 20 76 6d 75 6c |Div(a->t|op, vmul| |00003980| 2c 20 76 64 69 76 29 20 | 2b 20 76 6f 66 66 3b 0d |, vdiv) |+ voff;.| |00003990| 09 62 2d 3e 62 6f 74 74 | 6f 6d 20 3d 20 4d 75 6c |.b->bott|om = Mul| |000039a0| 44 69 76 28 61 2d 3e 62 | 6f 74 74 6f 6d 2c 20 76 |Div(a->b|ottom, v| |000039b0| 6d 75 6c 2c 20 76 64 69 | 76 29 20 2b 20 76 6f 66 |mul, vdi|v) + vof| |000039c0| 66 3b 0d 7d 0d 0d 2f 2a | 0d 20 2a 20 43 61 6c 63 |f;.}../*|. * Calc| |000039d0| 75 6c 61 74 65 20 68 6f | 77 20 6d 61 6e 79 20 28 |ulate ho|w many (| |000039e0| 75 6e 63 6f 6d 70 72 65 | 73 73 65 64 29 20 62 79 |uncompre|ssed) by| |000039f0| 74 65 73 20 69 6e 20 61 | 20 73 63 61 6e 6c 69 6e |tes in a| scanlin| |00003a00| 65 2e 0d 20 2a 20 44 6f | 65 73 6e 27 74 20 77 6f |e.. * Do|esn't wo| |00003a10| 72 6b 20 66 6f 72 20 73 | 65 70 61 72 61 74 65 64 |rk for s|eparated| |00003a20| 20 70 6c 61 6e 65 73 2e | 0d 20 2a 20 52 65 74 75 | planes.|. * Retu| |00003a30| 72 6e 73 20 2d 31 20 6f | 6e 20 65 72 72 6f 72 2e |rns -1 o|n error.| |00003a40| 0d 20 2a 2f 0d 6c 6f 6e | 67 0d 52 6f 77 42 79 74 |. */.lon|g.RowByt| |00003a50| 65 73 28 54 49 46 46 50 | 74 72 20 74 69 29 0d 7b |es(TIFFP|tr ti).{| |00003a60| 0d 09 6c 6f 6e 67 20 72 | 6f 77 62 79 74 65 73 3b |..long r|owbytes;| |00003a70| 0d 09 0d 09 69 66 28 74 | 69 2d 3e 70 6c 61 6e 61 |....if(t|i->plana| |00003a80| 72 43 6f 6e 66 69 67 75 | 72 61 74 69 6f 6e 20 21 |rConfigu|ration !| |00003a90| 3d 20 50 43 43 6f 6e 74 | 69 67 75 6f 75 73 29 7b |= PCCont|iguous){| |00003aa0| 0d 09 09 54 49 46 46 45 | 72 72 6f 72 28 74 69 2c |...TIFFE|rror(ti,| |00003ab0| 20 2d 31 2c 20 22 5c 70 | 43 61 6e 6e 6f 74 20 75 | -1, "\p|Cannot u| |00003ac0| 6e 64 65 72 73 74 61 6e | 64 20 70 6c 61 6e 61 72 |nderstan|d planar| |00003ad0| 20 64 61 74 61 2e 22 29 | 3b 0d 09 09 72 65 74 75 | data.")|;...retu| |00003ae0| 72 6e 28 2d 31 29 3b 0d | 09 7d 0d 09 09 0d 09 72 |rn(-1);.|.}.....r| |00003af0| 6f 77 62 79 74 65 73 20 | 3d 20 28 74 69 2d 3e 62 |owbytes |= (ti->b| |00003b00| 69 74 73 50 65 72 53 61 | 6d 70 6c 65 5b 30 5d 20 |itsPerSa|mple[0] | |00003b10| 2a 20 74 69 2d 3e 73 61 | 6d 70 6c 65 73 50 65 72 |* ti->sa|mplesPer| |00003b20| 50 69 78 65 6c 20 2a 20 | 74 69 2d 3e 69 6d 61 67 |Pixel * |ti->imag| |00003b30| 65 57 69 64 74 68 20 2b | 20 37 29 20 2f 20 38 3b |eWidth +| 7) / 8;| |00003b40| 0d 09 0d 09 72 65 74 75 | 72 6e 28 72 6f 77 62 79 |....retu|rn(rowby| |00003b50| 74 65 73 29 3b 0d 7d 0d | 0d 2f 2a 0d 20 2a 20 52 |tes);.}.|./*. * R| |00003b60| 65 61 64 20 61 20 72 65 | 61 73 6f 6e 61 62 6c 65 |ead a re|asonable| |00003b70| 20 6e 75 6d 62 65 72 20 | 6f 66 20 73 63 61 6e 20 | number |of scan | |00003b80| 6c 69 6e 65 73 20 66 72 | 6f 6d 20 61 6e 20 69 6d |lines fr|om an im| |00003b90| 61 67 65 2c 20 75 6e 63 | 6f 6d 70 72 65 73 73 20 |age, unc|ompress | |00003ba0| 74 68 65 6d 20 69 66 0d | 20 2a 20 6e 65 63 65 73 |them if.| * neces| |00003bb0| 73 61 72 79 2c 20 61 6e | 64 20 72 65 74 75 72 6e |sary, an|d return| |00003bc0| 20 61 20 6e 65 77 20 70 | 6f 69 6e 74 65 72 20 74 | a new p|ointer t| |00003bd0| 6f 20 74 68 65 20 64 61 | 74 61 2e 20 46 6f 72 20 |o the da|ta. For | |00003be0| 63 6f 6d 70 72 65 73 73 | 65 64 20 69 6d 61 67 65 |compress|ed image| |00003bf0| 73 2c 0d 20 2a 20 74 68 | 69 73 20 72 6f 75 74 69 |s,. * th|is routi| |00003c00| 6e 65 20 61 6c 77 61 79 | 73 20 72 65 61 64 73 20 |ne alway|s reads | |00003c10| 65 78 61 63 74 6c 79 20 | 6f 6e 65 20 73 74 72 69 |exactly |one stri| |00003c20| 70 2e 20 53 69 6e 63 65 | 20 73 6f 6d 65 20 61 70 |p. Since| some ap| |00003c30| 70 6c 69 63 61 74 69 6f | 6e 73 20 77 72 69 74 65 |plicatio|ns write| |00003c40| 0d 20 2a 20 6c 61 72 67 | 65 20 75 6e 63 6f 6d 70 |. * larg|e uncomp| |00003c50| 72 65 73 73 65 64 20 69 | 6d 61 67 65 73 20 61 73 |ressed i|mages as| |00003c60| 20 61 20 73 69 6e 67 6c | 65 20 73 74 72 69 70 2c | a singl|e strip,| |00003c70| 20 74 68 69 73 20 72 6f | 75 74 69 6e 65 20 74 72 | this ro|utine tr| |00003c80| 69 65 73 20 74 6f 20 72 | 65 61 64 0d 20 2a 20 6f |ies to r|ead. * o| |00003c90| 6e 6c 79 20 61 62 6f 75 | 74 20 36 34 4b 20 61 74 |nly abou|t 64K at| |00003ca0| 20 61 20 74 69 6d 65 2e | 20 52 65 61 64 53 74 72 | a time.| ReadStr| |00003cb0| 69 70 28 29 20 72 65 74 | 75 72 6e 73 20 74 68 65 |ip() ret|urns the| |00003cc0| 20 6e 75 6d 62 65 72 20 | 6f 66 20 6c 69 6e 65 73 | number |of lines| |00003cd0| 20 61 63 74 75 61 6c 6c | 79 0d 20 2a 20 72 65 61 | actuall|y. * rea| |00003ce0| 64 20 69 6e 20 2a 6c 69 | 6e 65 73 72 65 61 64 2c |d in *li|nesread,| |00003cf0| 20 61 6e 64 20 74 68 65 | 20 66 69 72 73 74 20 6c | and the| first l| |00003d00| 69 6e 65 20 61 63 74 75 | 61 6c 6c 79 20 72 65 61 |ine actu|ally rea| |00003d10| 64 20 69 6e 20 2a 66 69 | 72 73 74 72 65 61 64 2e |d in *fi|rstread.| |00003d20| 20 54 68 65 0d 20 2a 20 | 6c 61 74 74 65 72 20 77 | The. * |latter w| |00003d30| 69 6c 6c 20 61 6c 77 61 | 79 73 20 62 65 20 3c 3d |ill alwa|ys be <=| |00003d40| 20 73 74 61 72 74 6c 69 | 6e 65 2e 0d 20 2a 2f 0d | startli|ne.. */.| |00003d50| 50 74 72 0d 52 65 61 64 | 53 74 72 69 70 28 54 49 |Ptr.Read|Strip(TI| |00003d60| 46 46 50 74 72 20 74 69 | 2c 20 6c 6f 6e 67 20 73 |FFPtr ti|, long s| |00003d70| 74 61 72 74 6c 69 6e 65 | 2c 20 6c 6f 6e 67 20 2a |tartline|, long *| |00003d80| 66 69 72 73 74 72 65 61 | 64 2c 20 6c 6f 6e 67 20 |firstrea|d, long | |00003d90| 2a 6c 69 6e 65 73 72 65 | 61 64 29 0d 7b 0d 09 6c |*linesre|ad).{..l| |00003da0| 6f 6e 67 20 63 6f 75 6e | 74 2c 20 72 6f 77 62 79 |ong coun|t, rowby| |00003db0| 74 65 73 2c 20 6f 66 66 | 73 65 74 2c 20 75 6e 63 |tes, off|set, unc| |00003dc0| 6f 75 6e 74 2c 20 69 2c | 20 6e 72 6f 77 73 2c 20 |ount, i,| nrows, | |00003dd0| 73 74 72 69 70 3b 0d 09 | 6c 6f 6e 67 20 73 6b 69 |strip;..|long ski| |00003de0| 70 2c 20 73 75 62 6f 66 | 66 73 65 74 3b 0d 09 50 |p, subof|fset;..P| |00003df0| 74 72 20 70 20 3d 20 30 | 2c 20 70 31 20 3d 20 30 |tr p = 0|, p1 = 0| |00003e00| 3b 0d 09 50 74 72 20 73 | 72 63 50 74 72 2c 20 64 |;..Ptr s|rcPtr, d| |00003e10| 73 74 50 74 72 3b 0d 09 | 0d 09 2f 2a 0d 09 20 2a |stPtr;..|../*.. *| |00003e20| 20 44 65 63 69 64 65 20 | 77 68 69 63 68 20 73 74 | Decide |which st| |00003e30| 72 69 70 20 74 6f 20 72 | 65 61 64 2e 0d 09 20 2a |rip to r|ead... *| |00003e40| 2f 0d 09 66 6f 72 28 73 | 74 72 69 70 20 3d 20 30 |/..for(s|trip = 0| |00003e50| 3b 20 73 74 72 69 70 20 | 3c 20 74 69 2d 3e 73 74 |; strip |< ti->st| |00003e60| 72 69 70 73 50 65 72 49 | 6d 61 67 65 3b 20 73 74 |ripsPerI|mage; st| |00003e70| 72 69 70 2b 2b 29 0d 09 | 09 69 66 28 73 74 61 72 |rip++)..|.if(star| |00003e80| 74 6c 69 6e 65 20 3e 3d | 20 73 74 72 69 70 2a 74 |tline >=| strip*t| |00003e90| 69 2d 3e 72 6f 77 73 50 | 65 72 53 74 72 69 70 20 |i->rowsP|erStrip | |00003ea0| 26 26 20 73 74 61 72 74 | 6c 69 6e 65 20 3c 20 28 |&& start|line < (| |00003eb0| 73 74 72 69 70 2b 31 29 | 2a 74 69 2d 3e 72 6f 77 |strip+1)|*ti->row| |00003ec0| 73 50 65 72 53 74 72 69 | 70 29 0d 09 09 09 62 72 |sPerStri|p)....br| |00003ed0| 65 61 6b 3b 0d 09 69 66 | 28 73 74 72 69 70 20 3e |eak;..if|(strip >| |00003ee0| 3d 20 74 69 2d 3e 73 74 | 72 69 70 73 50 65 72 49 |= ti->st|ripsPerI| |00003ef0| 6d 61 67 65 29 7b 0d 09 | 09 54 49 46 46 45 72 72 |mage){..|.TIFFErr| |00003f00| 6f 72 28 74 69 2c 20 2d | 31 2c 20 22 5c 70 42 61 |or(ti, -|1, "\pBa| |00003f10| 64 20 61 72 67 20 74 6f | 20 52 65 61 64 53 74 72 |d arg to| ReadStr| |00003f20| 69 70 28 29 22 29 3b 0d | 09 09 72 65 74 75 72 6e |ip()");.|..return| |00003f30| 28 30 29 3b 0d 09 7d 0d | 09 0d 09 2f 2a 0d 09 20 |(0);..}.|.../*.. | |00003f40| 2a 20 44 65 63 69 64 65 | 20 68 6f 77 20 6d 61 6e |* Decide| how man| |00003f50| 79 20 72 6f 77 73 20 69 | 6e 20 74 68 69 73 20 73 |y rows i|n this s| |00003f60| 74 72 69 70 3b 20 74 68 | 65 20 6c 61 73 74 20 73 |trip; th|e last s| |00003f70| 74 72 69 70 20 6d 69 67 | 68 74 20 68 61 76 65 0d |trip mig|ht have.| |00003f80| 09 20 2a 20 66 65 77 65 | 72 20 74 68 61 6e 20 74 |. * fewe|r than t| |00003f90| 68 65 20 6f 74 68 65 72 | 73 2e 0d 09 20 2a 2f 0d |he other|s... */.| |00003fa0| 09 6e 72 6f 77 73 20 3d | 20 74 69 2d 3e 72 6f 77 |.nrows =| ti->row| |00003fb0| 73 50 65 72 53 74 72 69 | 70 3b 0d 09 69 66 28 28 |sPerStri|p;..if((| |00003fc0| 73 74 72 69 70 20 2a 20 | 74 69 2d 3e 72 6f 77 73 |strip * |ti->rows| |00003fd0| 50 65 72 53 74 72 69 70 | 29 20 2b 20 6e 72 6f 77 |PerStrip|) + nrow| |00003fe0| 73 20 3e 20 74 69 2d 3e | 69 6d 61 67 65 4c 65 6e |s > ti->|imageLen| |00003ff0| 67 74 68 29 0d 09 09 6e | 72 6f 77 73 20 3d 20 74 |gth)...n|rows = t| |00004000| 69 2d 3e 69 6d 61 67 65 | 4c 65 6e 67 74 68 20 2d |i->image|Length -| |00004010| 20 28 73 74 72 69 70 20 | 2a 20 74 69 2d 3e 72 6f | (strip |* ti->ro| |00004020| 77 73 50 65 72 53 74 72 | 69 70 29 3b 0d 09 0d 09 |wsPerStr|ip);....| |00004030| 69 66 28 74 69 2d 3e 73 | 74 72 69 70 4f 66 66 73 |if(ti->s|tripOffs| |00004040| 65 74 73 20 3d 3d 20 30 | 29 7b 0d 09 09 54 49 46 |ets == 0|){...TIF| |00004050| 46 45 72 72 6f 72 28 74 | 69 2c 20 2d 31 2c 20 22 |FError(t|i, -1, "| |00004060| 5c 70 4e 6f 20 73 74 72 | 69 70 20 6f 66 66 73 65 |\pNo str|ip offse| |00004070| 74 73 2e 22 29 3b 0d 09 | 09 72 65 74 75 72 6e 28 |ts.");..|.return(| |00004080| 30 29 3b 0d 09 7d 0d 09 | 6f 66 66 73 65 74 20 3d |0);..}..|offset =| |00004090| 20 74 69 2d 3e 73 74 72 | 69 70 4f 66 66 73 65 74 | ti->str|ipOffset| |000040a0| 73 5b 73 74 72 69 70 5d | 3b 0d 09 0d 09 69 66 28 |s[strip]|;....if(| |000040b0| 74 69 2d 3e 63 6f 6d 70 | 72 65 73 73 69 6f 6e 20 |ti->comp|ression | |000040c0| 3d 3d 20 4e 6f 43 6f 6d | 70 72 65 73 73 69 6f 6e |== NoCom|pression| |000040d0| 29 7b 0d 09 09 2f 2a 0d | 09 09 20 2a 20 4a 75 73 |){.../*.|.. * Jus| |000040e0| 74 20 72 65 61 64 20 70 | 61 72 74 20 6f 66 20 61 |t read p|art of a| |000040f0| 20 73 74 72 69 70 2e 0d | 09 09 20 2a 2f 0d 09 09 | strip..|.. */...| |00004100| 69 66 28 28 72 6f 77 62 | 79 74 65 73 20 3d 20 52 |if((rowb|ytes = R| |00004110| 6f 77 42 79 74 65 73 28 | 74 69 29 29 20 3d 3d 20 |owBytes(|ti)) == | |00004120| 2d 31 29 0d 09 09 09 72 | 65 74 75 72 6e 28 30 29 |-1)....r|eturn(0)| |00004130| 3b 0d 09 09 73 6b 69 70 | 20 3d 20 73 74 61 72 74 |;...skip| = start| |00004140| 6c 69 6e 65 20 2d 20 28 | 73 74 72 69 70 20 2a 20 |line - (|strip * | |00004150| 74 69 2d 3e 72 6f 77 73 | 50 65 72 53 74 72 69 70 |ti->rows|PerStrip| |00004160| 29 3b 0d 09 09 73 75 62 | 6f 66 66 73 65 74 20 3d |);...sub|offset =| |00004170| 20 6f 66 66 73 65 74 20 | 2b 20 28 73 6b 69 70 20 | offset |+ (skip | |00004180| 2a 20 72 6f 77 62 79 74 | 65 73 29 3b 0d 09 09 6e |* rowbyt|es);...n| |00004190| 72 6f 77 73 20 2d 3d 20 | 73 6b 69 70 3b 0d 23 64 |rows -= |skip;.#d| |000041a0| 65 66 69 6e 65 20 42 55 | 46 53 49 5a 45 20 36 34 |efine BU|FSIZE 64| |000041b0| 30 30 30 4c 0d 09 09 69 | 66 28 72 6f 77 62 79 74 |000L...i|f(rowbyt| |000041c0| 65 73 20 3e 3d 20 42 55 | 46 53 49 5a 45 29 7b 0d |es >= BU|FSIZE){.| |000041d0| 09 09 09 6e 72 6f 77 73 | 20 3d 20 31 3b 0d 09 09 |...nrows| = 1;...| |000041e0| 7d 20 65 6c 73 65 20 69 | 66 28 28 6e 72 6f 77 73 |} else i|f((nrows| |000041f0| 20 2a 20 72 6f 77 62 79 | 74 65 73 29 20 3e 20 42 | * rowby|tes) > B| |00004200| 55 46 53 49 5a 45 29 7b | 0d 09 09 09 6e 72 6f 77 |UFSIZE){|....nrow| |00004210| 73 20 3d 20 42 55 46 53 | 49 5a 45 20 2f 20 72 6f |s = BUFS|IZE / ro| |00004220| 77 62 79 74 65 73 3b 0d | 09 09 7d 0d 09 09 63 6f |wbytes;.|..}...co| |00004230| 75 6e 74 20 3d 20 72 6f | 77 62 79 74 65 73 20 2a |unt = ro|wbytes *| |00004240| 20 6e 72 6f 77 73 3b 0d | 09 0d 09 09 70 20 3d 20 | nrows;.|....p = | |00004250| 4e 65 77 50 74 72 28 63 | 6f 75 6e 74 29 3b 0d 09 |NewPtr(c|ount);..| |00004260| 09 69 66 28 70 20 3d 3d | 20 30 29 7b 0d 09 09 09 |.if(p ==| 0){....| |00004270| 54 49 46 46 45 72 72 6f | 72 28 74 69 2c 20 4d 65 |TIFFErro|r(ti, Me| |00004280| 6d 45 72 72 6f 72 28 29 | 2c 20 22 5c 70 4f 75 74 |mError()|, "\pOut| |00004290| 20 6f 66 20 6d 65 6d 6f | 72 79 2e 22 29 3b 0d 09 | of memo|ry.");..| |000042a0| 09 09 72 65 74 75 72 6e | 28 30 29 3b 0d 09 09 7d |..return|(0);...}| |000042b0| 0d 09 0d 09 09 69 66 28 | 74 69 66 66 5f 72 65 61 |.....if(|tiff_rea| |000042c0| 64 28 74 69 2c 20 73 75 | 62 6f 66 66 73 65 74 2c |d(ti, su|boffset,| |000042d0| 20 70 2c 20 63 6f 75 6e | 74 29 20 21 3d 20 30 29 | p, coun|t) != 0)| |000042e0| 0d 09 09 09 67 6f 74 6f | 20 62 61 64 3b 0d 09 09 |....goto| bad;...| |000042f0| 09 0d 09 09 2a 66 69 72 | 73 74 72 65 61 64 20 3d |....*fir|stread =| |00004300| 20 73 74 61 72 74 6c 69 | 6e 65 3b 0d 09 09 2a 6c | startli|ne;...*l| |00004310| 69 6e 65 73 72 65 61 64 | 20 3d 20 6e 72 6f 77 73 |inesread| = nrows| |00004320| 3b 0d 09 09 0d 09 09 72 | 65 74 75 72 6e 28 70 29 |;......r|eturn(p)| |00004330| 3b 0d 09 7d 0d 09 09 0d | 09 69 66 28 74 69 2d 3e |;..}....|.if(ti->| |00004340| 73 74 72 69 70 42 79 74 | 65 43 6f 75 6e 74 73 29 |stripByt|eCounts)| |00004350| 7b 0d 09 09 63 6f 75 6e | 74 20 3d 20 74 69 2d 3e |{...coun|t = ti->| |00004360| 73 74 72 69 70 42 79 74 | 65 43 6f 75 6e 74 73 5b |stripByt|eCounts[| |00004370| 73 74 72 69 70 5d 3b 0d | 09 7d 20 65 6c 73 65 20 |strip];.|.} else | |00004380| 7b 0d 09 09 2f 2a 20 63 | 61 6e 6e 6f 74 20 67 75 |{.../* c|annot gu| |00004390| 65 73 73 20 73 74 72 69 | 70 20 6c 65 6e 67 74 68 |ess stri|p length| |000043a0| 20 2a 2f 0d 09 09 72 65 | 74 75 72 6e 28 30 29 3b | */...re|turn(0);| |000043b0| 0d 09 7d 09 09 0d 09 0d | 09 70 20 3d 20 4e 65 77 |..}.....|.p = New| |000043c0| 50 74 72 28 63 6f 75 6e | 74 29 3b 0d 09 69 66 28 |Ptr(coun|t);..if(| |000043d0| 70 20 3d 3d 20 30 29 7b | 0d 09 09 54 49 46 46 45 |p == 0){|...TIFFE| |000043e0| 72 72 6f 72 28 74 69 2c | 20 4d 65 6d 45 72 72 6f |rror(ti,| MemErro| |000043f0| 72 28 29 2c 20 22 5c 70 | 4f 75 74 20 6f 66 20 6d |r(), "\p|Out of m| |00004400| 65 6d 6f 72 79 2e 22 29 | 3b 0d 09 09 72 65 74 75 |emory.")|;...retu| |00004410| 72 6e 28 30 29 3b 0d 09 | 7d 0d 0d 09 69 66 28 74 |rn(0);..|}...if(t| |00004420| 69 66 66 5f 72 65 61 64 | 28 74 69 2c 20 6f 66 66 |iff_read|(ti, off| |00004430| 73 65 74 2c 20 70 2c 20 | 63 6f 75 6e 74 29 20 21 |set, p, |count) !| |00004440| 3d 20 30 29 0d 09 09 67 | 6f 74 6f 20 62 61 64 3b |= 0)...g|oto bad;| |00004450| 0d 09 0d 09 69 66 28 74 | 69 2d 3e 63 6f 6d 70 72 |....if(t|i->compr| |00004460| 65 73 73 69 6f 6e 20 3d | 3d 20 54 36 43 6f 6d 70 |ession =|= T6Comp| |00004470| 72 65 73 73 69 6f 6e 29 | 7b 0d 09 09 72 6f 77 62 |ression)|{...rowb| |00004480| 79 74 65 73 20 3d 20 52 | 6f 77 42 79 74 65 73 28 |ytes = R|owBytes(| |00004490| 74 69 29 3b 0d 09 09 69 | 66 28 72 6f 77 62 79 74 |ti);...i|f(rowbyt| |000044a0| 65 73 20 3d 3d 20 2d 31 | 29 0d 09 09 09 67 6f 74 |es == -1|)....got| |000044b0| 6f 20 62 61 64 3b 0d 09 | 09 75 6e 63 6f 75 6e 74 |o bad;..|.uncount| |000044c0| 20 3d 20 72 6f 77 62 79 | 74 65 73 20 2a 20 74 69 | = rowby|tes * ti| |000044d0| 2d 3e 72 6f 77 73 50 65 | 72 53 74 72 69 70 3b 0d |->rowsPe|rStrip;.| |000044e0| 09 09 70 31 20 3d 20 4e | 65 77 50 74 72 28 75 6e |..p1 = N|ewPtr(un| |000044f0| 63 6f 75 6e 74 29 3b 0d | 09 09 69 66 28 70 31 20 |count);.|..if(p1 | |00004500| 3d 3d 20 30 29 7b 0d 09 | 09 09 54 49 46 46 45 72 |== 0){..|..TIFFEr| |00004510| 72 6f 72 28 74 69 2c 20 | 4d 65 6d 45 72 72 6f 72 |ror(ti, |MemError| |00004520| 28 29 2c 20 22 5c 70 4f | 75 74 20 6f 66 20 6d 65 |(), "\pO|ut of me| |00004530| 6d 6f 72 79 2e 22 29 3b | 0d 09 09 09 67 6f 74 6f |mory.");|....goto| |00004540| 20 62 61 64 3b 0d 09 09 | 7d 0d 09 09 69 66 28 44 | bad;...|}...if(D| |00004550| 65 63 6f 64 65 54 36 28 | 74 69 2c 20 70 2c 20 63 |ecodeT6(|ti, p, c| |00004560| 6f 75 6e 74 2c 20 70 31 | 2c 20 75 6e 63 6f 75 6e |ount, p1|, uncoun| |00004570| 74 29 20 21 3d 20 30 29 | 0d 09 09 09 67 6f 74 6f |t) != 0)|....goto| |00004580| 20 62 61 64 3b 0d 09 09 | 44 69 73 70 6f 73 50 74 | bad;...|DisposPt| |00004590| 72 28 70 29 3b 0d 09 09 | 70 20 3d 20 70 31 3b 0d |r(p);...|p = p1;.| |000045a0| 09 09 70 31 20 3d 20 30 | 3b 0d 09 7d 20 65 6c 73 |..p1 = 0|;..} els| |000045b0| 65 20 69 66 28 74 69 2d | 3e 63 6f 6d 70 72 65 73 |e if(ti-|>compres| |000045c0| 73 69 6f 6e 20 3d 3d 20 | 4c 5a 57 43 6f 6d 70 72 |sion == |LZWCompr| |000045d0| 65 73 73 69 6f 6e 29 7b | 0d 09 09 72 6f 77 62 79 |ession){|...rowby| |000045e0| 74 65 73 20 3d 20 52 6f | 77 42 79 74 65 73 28 74 |tes = Ro|wBytes(t| |000045f0| 69 29 3b 0d 09 09 69 66 | 28 72 6f 77 62 79 74 65 |i);...if|(rowbyte| |00004600| 73 20 3d 3d 20 2d 31 29 | 0d 09 09 09 67 6f 74 6f |s == -1)|....goto| |00004610| 20 62 61 64 3b 0d 09 09 | 75 6e 63 6f 75 6e 74 20 | bad;...|uncount | |00004620| 3d 20 72 6f 77 62 79 74 | 65 73 20 2a 20 74 69 2d |= rowbyt|es * ti-| |00004630| 3e 72 6f 77 73 50 65 72 | 53 74 72 69 70 3b 0d 09 |>rowsPer|Strip;..| |00004640| 09 70 31 20 3d 20 4e 65 | 77 50 74 72 28 75 6e 63 |.p1 = Ne|wPtr(unc| |00004650| 6f 75 6e 74 29 3b 0d 09 | 09 69 66 28 70 31 20 3d |ount);..|.if(p1 =| |00004660| 3d 20 30 29 7b 0d 09 09 | 09 54 49 46 46 45 72 72 |= 0){...|.TIFFErr| |00004670| 6f 72 28 74 69 2c 20 4d | 65 6d 45 72 72 6f 72 28 |or(ti, M|emError(| |00004680| 29 2c 20 22 5c 70 4f 75 | 74 20 6f 66 20 6d 65 6d |), "\pOu|t of mem| |00004690| 6f 72 79 2e 22 29 3b 0d | 09 09 09 67 6f 74 6f 20 |ory.");.|...goto | |000046a0| 62 61 64 3b 0d 09 09 7d | 0d 09 09 0d 09 09 69 66 |bad;...}|......if| |000046b0| 28 55 6e 4c 5a 57 28 70 | 2c 20 63 6f 75 6e 74 2c |(UnLZW(p|, count,| |000046c0| 20 70 31 2c 20 75 6e 63 | 6f 75 6e 74 29 20 21 3d | p1, unc|ount) !=| |000046d0| 20 30 29 7b 0d 09 09 09 | 54 49 46 46 45 72 72 6f | 0){....|TIFFErro| |000046e0| 72 28 74 69 2c 20 2d 31 | 2c 20 22 5c 70 4c 5a 57 |r(ti, -1|, "\pLZW| |000046f0| 20 64 65 63 6f 6d 70 72 | 65 73 73 69 6f 6e 20 66 | decompr|ession f| |00004700| 61 69 6c 65 64 2e 22 29 | 3b 0d 09 09 09 67 6f 74 |ailed.")|;....got| |00004710| 6f 20 62 61 64 3b 0d 09 | 09 7d 0d 09 09 44 69 73 |o bad;..|.}...Dis| |00004720| 70 6f 73 50 74 72 28 70 | 29 3b 0d 09 09 70 20 3d |posPtr(p|);...p =| |00004730| 20 70 31 3b 0d 09 09 70 | 31 20 3d 20 30 3b 0d 09 | p1;...p|1 = 0;..| |00004740| 09 0d 09 09 69 66 28 74 | 69 2d 3e 70 72 65 64 69 |....if(t|i->predi| |00004750| 63 74 6f 72 20 3d 3d 20 | 48 44 50 72 65 64 69 63 |ctor == |HDPredic| |00004760| 74 6f 72 20 26 26 0d 09 | 09 20 20 20 74 69 2d 3e |tor &&..|. ti->| |00004770| 62 69 74 73 50 65 72 53 | 61 6d 70 6c 65 5b 30 5d |bitsPerS|ample[0]| |00004780| 20 3d 3d 20 38 20 26 26 | 0d 09 09 20 20 20 74 69 | == 8 &&|... ti| |00004790| 2d 3e 70 6c 61 6e 61 72 | 43 6f 6e 66 69 67 75 72 |->planar|Configur| |000047a0| 61 74 69 6f 6e 20 3d 3d | 20 50 43 43 6f 6e 74 69 |ation ==| PCConti| |000047b0| 67 75 6f 75 73 29 7b 0d | 09 09 09 2f 2a 20 68 6f |guous){.|.../* ho| |000047c0| 72 69 7a 6f 6e 74 61 6c | 20 64 69 66 66 65 72 65 |rizontal| differe| |000047d0| 6e 63 69 6e 67 20 2a 2f | 0d 09 09 09 66 6f 72 28 |ncing */|....for(| |000047e0| 69 20 3d 20 30 3b 20 69 | 20 3c 20 74 69 2d 3e 73 |i = 0; i| < ti->s| |000047f0| 61 6d 70 6c 65 73 50 65 | 72 50 69 78 65 6c 3b 20 |amplesPe|rPixel; | |00004800| 69 2b 2b 29 0d 09 09 09 | 09 55 6e 44 69 66 66 65 |i++)....|.UnDiffe| |00004810| 72 65 6e 63 65 28 70 2b | 69 2c 20 72 6f 77 62 79 |rence(p+|i, rowby| |00004820| 74 65 73 2c 20 74 69 2d | 3e 72 6f 77 73 50 65 72 |tes, ti-|>rowsPer| |00004830| 53 74 72 69 70 2c 20 74 | 69 2d 3e 73 61 6d 70 6c |Strip, t|i->sampl| |00004840| 65 73 50 65 72 50 69 78 | 65 6c 29 3b 0d 09 09 7d |esPerPix|el);...}| |00004850| 20 65 6c 73 65 20 69 66 | 28 74 69 2d 3e 70 72 65 | else if|(ti->pre| |00004860| 64 69 63 74 6f 72 20 21 | 3d 20 4e 6f 50 72 65 64 |dictor !|= NoPred| |00004870| 69 63 74 6f 72 29 7b 0d | 09 09 09 54 49 46 46 45 |ictor){.|...TIFFE| |00004880| 72 72 6f 72 28 74 69 2c | 20 2d 31 2c 20 22 5c 70 |rror(ti,| -1, "\p| |00004890| 55 6e 69 6d 70 6c 65 6d | 65 6e 74 65 64 20 4c 5a |Unimplem|ented LZ| |000048a0| 57 20 70 72 65 64 69 63 | 74 69 6f 6e 20 74 79 70 |W predic|tion typ| |000048b0| 65 2e 22 29 3b 0d 09 09 | 09 67 6f 74 6f 20 62 61 |e.");...|.goto ba| |000048c0| 64 3b 0d 09 09 7d 0d 09 | 7d 20 65 6c 73 65 20 69 |d;...}..|} else i| |000048d0| 66 28 74 69 2d 3e 63 6f | 6d 70 72 65 73 73 69 6f |f(ti->co|mpressio| |000048e0| 6e 20 3d 3d 20 50 61 63 | 6b 43 6f 6d 70 72 65 73 |n == Pac|kCompres| |000048f0| 73 69 6f 6e 29 7b 0d 09 | 09 72 6f 77 62 79 74 65 |sion){..|.rowbyte| |00004900| 73 20 3d 20 52 6f 77 42 | 79 74 65 73 28 74 69 29 |s = RowB|ytes(ti)| |00004910| 3b 0d 09 09 69 66 28 72 | 6f 77 62 79 74 65 73 20 |;...if(r|owbytes | |00004920| 3d 3d 20 2d 31 29 0d 09 | 09 09 67 6f 74 6f 20 62 |== -1)..|..goto b| |00004930| 61 64 3b 0d 09 09 69 66 | 28 72 6f 77 62 79 74 65 |ad;...if|(rowbyte| |00004940| 73 20 3e 20 33 32 37 36 | 37 29 7b 0d 09 09 09 54 |s > 3276|7){....T| |00004950| 49 46 46 45 72 72 6f 72 | 28 74 69 2c 20 2d 31 2c |IFFError|(ti, -1,| |00004960| 20 22 5c 70 52 6f 77 20 | 74 6f 6f 20 6c 6f 6e 67 | "\pRow |too long| |00004970| 20 66 6f 72 20 55 6e 70 | 61 63 6b 42 69 74 73 2e | for Unp|ackBits.| |00004980| 22 29 3b 0d 09 09 09 67 | 6f 74 6f 20 62 61 64 3b |");....g|oto bad;| |00004990| 0d 09 09 7d 0d 09 09 75 | 6e 63 6f 75 6e 74 20 3d |...}...u|ncount =| |000049a0| 20 72 6f 77 62 79 74 65 | 73 20 2a 20 74 69 2d 3e | rowbyte|s * ti->| |000049b0| 72 6f 77 73 50 65 72 53 | 74 72 69 70 3b 0d 09 09 |rowsPerS|trip;...| |000049c0| 70 31 20 3d 20 4e 65 77 | 50 74 72 28 75 6e 63 6f |p1 = New|Ptr(unco| |000049d0| 75 6e 74 29 3b 0d 09 09 | 69 66 28 70 31 20 3d 3d |unt);...|if(p1 ==| |000049e0| 20 30 29 7b 0d 09 09 09 | 54 49 46 46 45 72 72 6f | 0){....|TIFFErro| |000049f0| 72 28 74 69 2c 20 4d 65 | 6d 45 72 72 6f 72 28 29 |r(ti, Me|mError()| |00004a00| 2c 20 22 5c 70 4f 75 74 | 20 6f 66 20 6d 65 6d 6f |, "\pOut| of memo| |00004a10| 72 79 2e 22 29 3b 0d 09 | 09 09 67 6f 74 6f 20 62 |ry.");..|..goto b| |00004a20| 61 64 3b 0d 09 09 7d 0d | 09 09 73 72 63 50 74 72 |ad;...}.|..srcPtr| |00004a30| 20 3d 20 70 3b 0d 09 09 | 66 6f 72 28 69 20 3d 20 | = p;...|for(i = | |00004a40| 30 3b 20 69 20 3c 20 6e | 72 6f 77 73 3b 20 69 2b |0; i < n|rows; i+| |00004a50| 2b 29 7b 0d 09 09 09 64 | 73 74 50 74 72 20 3d 20 |+){....d|stPtr = | |00004a60| 70 31 20 2b 20 28 69 20 | 2a 20 72 6f 77 62 79 74 |p1 + (i |* rowbyt| |00004a70| 65 73 29 3b 0d 09 09 09 | 2f 2a 20 64 6f 65 73 20 |es);....|/* does | |00004a80| 55 6e 70 61 63 6b 42 69 | 74 73 20 72 65 73 74 72 |UnpackBi|ts restr| |00004a90| 69 63 74 20 74 68 65 20 | 73 69 7a 65 20 6f 66 20 |ict the |size of | |00004aa0| 72 6f 77 62 79 74 65 73 | 3f 20 2a 2f 0d 09 09 09 |rowbytes|? */....| |00004ab0| 55 6e 70 61 63 6b 42 69 | 74 73 28 26 73 72 63 50 |UnpackBi|ts(&srcP| |00004ac0| 74 72 2c 20 26 64 73 74 | 50 74 72 2c 20 28 69 6e |tr, &dst|Ptr, (in| |00004ad0| 74 29 72 6f 77 62 79 74 | 65 73 29 3b 0d 09 09 7d |t)rowbyt|es);...}| |00004ae0| 0d 09 09 44 69 73 70 6f | 73 50 74 72 28 70 29 3b |...Dispo|sPtr(p);| |00004af0| 0d 09 09 70 20 3d 20 70 | 31 3b 0d 09 09 70 31 20 |...p = p|1;...p1 | |00004b00| 3d 20 30 3b 0d 09 7d 20 | 65 6c 73 65 20 7b 0d 09 |= 0;..} |else {..| |00004b10| 09 54 49 46 46 45 72 72 | 6f 72 28 74 69 2c 20 2d |.TIFFErr|or(ti, -| |00004b20| 31 2c 20 22 5c 70 55 6e | 69 6d 70 6c 65 6d 65 6e |1, "\pUn|implemen| |00004b30| 74 65 64 20 63 6f 6d 70 | 72 65 73 73 69 6f 6e 20 |ted comp|ression | |00004b40| 74 79 70 65 2e 22 29 3b | 0d 09 09 67 6f 74 6f 20 |type.");|...goto | |00004b50| 62 61 64 3b 0d 09 7d 0d | 09 0d 09 2a 66 69 72 73 |bad;..}.|...*firs| |00004b60| 74 72 65 61 64 20 3d 20 | 73 74 72 69 70 20 2a 20 |tread = |strip * | |00004b70| 74 69 2d 3e 72 6f 77 73 | 50 65 72 53 74 72 69 70 |ti->rows|PerStrip| |00004b80| 3b 0d 09 2a 6c 69 6e 65 | 73 72 65 61 64 20 3d 20 |;..*line|sread = | |00004b90| 6e 72 6f 77 73 3b 0d 09 | 0d 09 72 65 74 75 72 6e |nrows;..|..return| |00004ba0| 28 70 29 3b 0d 09 0d 62 | 61 64 3a 0d 09 69 66 28 |(p);...b|ad:..if(| |00004bb0| 70 29 0d 09 09 44 69 73 | 70 6f 73 50 74 72 28 70 |p)...Dis|posPtr(p| |00004bc0| 29 3b 0d 09 69 66 28 70 | 31 29 0d 09 09 44 69 73 |);..if(p|1)...Dis| |00004bd0| 70 6f 73 50 74 72 28 70 | 31 29 3b 0d 09 72 65 74 |posPtr(p|1);..ret| |00004be0| 75 72 6e 28 30 29 3b 0d | 7d 0d 0d 2f 2a 0d 20 2a |urn(0);.|}../*. *| |00004bf0| 20 44 72 61 77 20 61 20 | 74 69 66 66 20 66 69 6c | Draw a |tiff fil| |00004c00| 65 20 69 6d 61 67 65 20 | 69 6e 20 74 68 65 20 63 |e image |in the c| |00004c10| 75 72 72 65 6e 74 20 51 | 75 69 63 6b 44 72 61 77 |urrent Q|uickDraw| |00004c20| 20 70 6f 72 74 2e 0d 20 | 2a 20 54 68 65 20 69 64 | port.. |* The id| |00004c30| 65 61 20 69 73 20 74 6f | 20 72 65 61 64 20 65 61 |ea is to| read ea| |00004c40| 63 68 20 73 74 72 69 70 | 2c 20 63 6f 6e 76 65 72 |ch strip|, conver| |00004c50| 74 20 69 6e 74 6f 20 61 | 20 66 6f 72 6d 0d 20 2a |t into a| form. *| |00004c60| 20 74 68 61 74 27 73 20 | 75 73 61 62 6c 65 20 61 | that's |usable a| |00004c70| 73 20 61 20 51 75 69 63 | 6b 44 72 61 77 20 50 69 |s a Quic|kDraw Pi| |00004c80| 78 4d 61 70 2c 20 61 6e | 64 20 63 6f 70 79 20 69 |xMap, an|d copy i| |00004c90| 74 20 74 6f 20 74 68 65 | 0d 20 2a 20 63 75 72 72 |t to the|. * curr| |00004ca0| 65 6e 74 20 70 6f 72 74 | 2e 20 41 73 20 61 6e 20 |ent port|. As an | |00004cb0| 6f 70 74 69 6d 69 7a 61 | 74 69 6f 6e 2c 20 64 6f |optimiza|tion, do| |00004cc0| 6e 27 74 20 62 6f 74 68 | 65 72 20 72 65 61 64 69 |n't both|er readi| |00004cd0| 6e 67 0d 20 2a 20 73 74 | 72 69 70 73 20 74 68 61 |ng. * st|rips tha| |00004ce0| 74 20 77 6f 6e 27 74 20 | 62 65 20 76 69 73 69 62 |t won't |be visib| |00004cf0| 6c 65 2e 0d 20 2a 2f 0d | 4f 53 45 72 72 0d 44 72 |le.. */.|OSErr.Dr| |00004d00| 61 77 54 49 46 46 28 69 | 6e 74 20 72 65 66 2c 20 |awTIFF(i|nt ref, | |00004d10| 54 49 46 46 50 74 72 20 | 74 69 2c 20 52 65 63 74 |TIFFPtr |ti, Rect| |00004d20| 20 73 72 2c 20 52 65 63 | 74 20 64 72 2c 20 69 6e | sr, Rec|t dr, in| |00004d30| 74 20 64 69 74 68 65 72 | 29 0d 7b 0d 09 6c 6f 6e |t dither|).{..lon| |00004d40| 67 20 79 2c 20 73 74 72 | 69 70 48 65 69 67 68 74 |g y, str|ipHeight| |00004d50| 2c 20 64 73 74 53 74 72 | 69 70 48 65 69 67 68 74 |, dstStr|ipHeight| |00004d60| 2c 20 69 2c 20 72 6f 77 | 62 79 74 65 73 3b 0d 09 |, i, row|bytes;..| |00004d70| 50 74 72 20 70 20 3d 20 | 30 2c 20 70 31 3b 0d 09 |Ptr p = |0, p1;..| |00004d80| 50 69 78 4d 61 70 48 61 | 6e 64 6c 65 20 70 6d 20 |PixMapHa|ndle pm | |00004d90| 3d 20 30 3b 0d 09 52 65 | 63 74 20 76 69 73 72 2c |= 0;..Re|ct visr,| |00004da0| 20 70 6f 72 74 72 3b 0d | 09 47 72 61 66 50 74 72 | portr;.|.GrafPtr| |00004db0| 20 70 6f 72 74 3b 0d 09 | 69 6e 74 20 70 70 62 2c | port;..|int ppb,| |00004dc0| 20 69 6e 76 3b 0d 09 42 | 69 74 4d 61 70 20 62 6d | inv;..B|itMap bm| |00004dd0| 3b 0d 09 0d 09 47 65 74 | 50 6f 72 74 28 26 70 6f |;....Get|Port(&po| |00004de0| 72 74 29 3b 0d 09 0d 09 | 2f 2a 0d 09 20 2a 20 4d |rt);....|/*.. * M| |00004df0| 61 6b 65 20 73 75 72 65 | 20 77 65 20 6b 6e 6f 77 |ake sure| we know| |00004e00| 20 68 6f 77 20 6d 61 6e | 79 20 62 69 74 73 20 74 | how man|y bits t| |00004e10| 68 65 72 65 20 61 72 65 | 20 70 65 72 20 73 61 6d |here are| per sam| |00004e20| 70 6c 65 2c 20 61 6e 64 | 20 74 68 61 74 0d 09 20 |ple, and| that.. | |00004e30| 2a 20 74 68 65 20 52 65 | 64 2c 20 47 72 65 65 6e |* the Re|d, Green| |00004e40| 2c 20 61 6e 64 20 42 6c | 75 65 20 63 68 61 6e 6e |, and Bl|ue chann| |00004e50| 65 6c 73 20 61 72 65 20 | 74 68 65 20 73 61 6d 65 |els are |the same| |00004e60| 20 73 69 7a 65 20 66 6f | 72 20 52 47 42 20 69 6d | size fo|r RGB im| |00004e70| 61 67 65 73 2e 0d 09 20 | 2a 2f 0d 09 69 66 28 74 |ages... |*/..if(t| |00004e80| 69 2d 3e 62 69 74 73 50 | 65 72 53 61 6d 70 6c 65 |i->bitsP|erSample| |00004e90| 20 3d 3d 20 30 29 7b 0d | 09 09 54 49 46 46 45 72 | == 0){.|..TIFFEr| |00004ea0| 72 6f 72 28 74 69 2c 20 | 2d 31 2c 20 22 5c 70 4e |ror(ti, |-1, "\pN| |00004eb0| 6f 20 62 69 74 73 2d 70 | 65 72 2d 73 61 6d 70 6c |o bits-p|er-sampl| |00004ec0| 65 20 67 69 76 65 6e 2e | 22 29 3b 0d 09 09 72 65 |e given.|");...re| |00004ed0| 74 75 72 6e 28 2d 31 29 | 3b 0d 09 7d 0d 09 66 6f |turn(-1)|;..}..fo| |00004ee0| 72 28 69 20 3d 20 31 3b | 20 69 20 3c 20 74 69 2d |r(i = 1;| i < ti-| |00004ef0| 3e 73 61 6d 70 6c 65 73 | 50 65 72 50 69 78 65 6c |>samples|PerPixel| |00004f00| 3b 20 69 2b 2b 29 7b 0d | 09 09 69 66 28 74 69 2d |; i++){.|..if(ti-| |00004f10| 3e 62 69 74 73 50 65 72 | 53 61 6d 70 6c 65 5b 69 |>bitsPer|Sample[i| |00004f20| 5d 20 21 3d 20 74 69 2d | 3e 62 69 74 73 50 65 72 |] != ti-|>bitsPer| |00004f30| 53 61 6d 70 6c 65 5b 69 | 2d 31 5d 29 7b 0d 09 09 |Sample[i|-1]){...| |00004f40| 09 54 49 46 46 45 72 72 | 6f 72 28 74 69 2c 20 2d |.TIFFErr|or(ti, -| |00004f50| 31 2c 20 22 5c 70 42 69 | 74 73 2d 70 65 72 2d 73 |1, "\pBi|ts-per-s| |00004f60| 61 6d 70 6c 65 20 61 72 | 65 20 64 69 66 66 65 72 |ample ar|e differ| |00004f70| 65 6e 74 2e 22 29 3b 0d | 09 09 09 72 65 74 75 72 |ent.");.|...retur| |00004f80| 6e 28 2d 31 29 3b 0d 09 | 09 7d 0d 09 7d 0d 09 0d |n(-1);..|.}..}...| |00004f90| 09 74 69 2d 3e 72 65 66 | 20 3d 20 72 65 66 3b 0d |.ti->ref| = ref;.| |00004fa0| 09 0d 09 2f 2a 0d 09 20 | 2a 20 54 68 65 20 64 65 |.../*.. |* The de| |00004fb0| 73 74 69 6e 61 74 69 6f | 6e 20 72 65 63 74 61 6e |stinatio|n rectan| |00004fc0| 67 6c 65 20 6d 61 79 20 | 6e 6f 74 20 62 65 20 74 |gle may |not be t| |00004fd0| 6f 74 61 6c 6c 79 20 76 | 69 73 69 62 6c 65 2e 20 |otally v|isible. | |00004fe0| 41 73 20 61 6e 20 6f 70 | 74 69 6d 69 7a 61 74 69 |As an op|timizati| |00004ff0| 6f 6e 2c 0d 09 20 2a 20 | 74 72 61 6e 73 6c 61 74 |on,.. * |translat| |00005000| 65 20 74 68 65 20 62 6f | 75 6e 64 69 6e 67 20 62 |e the bo|unding b| |00005010| 6f 78 20 6f 66 20 74 68 | 65 20 76 69 73 69 62 6c |ox of th|e visibl| |00005020| 65 20 61 72 65 61 20 69 | 6e 74 6f 20 74 68 65 20 |e area i|nto the | |00005030| 73 6f 75 72 63 65 20 69 | 6d 61 67 65 0d 09 20 2a |source i|mage.. *| |00005040| 20 73 70 61 63 65 2c 20 | 61 6e 64 20 6f 6e 6c 79 | space, |and only| |00005050| 20 63 6f 70 79 20 74 68 | 65 20 72 65 6c 65 76 61 | copy th|e releva| |00005060| 6e 74 20 73 74 72 69 70 | 73 2e 0d 09 20 2a 2f 0d |nt strip|s... */.| |00005070| 09 70 6f 72 74 72 20 3d | 20 28 2a 28 70 6f 72 74 |.portr =| (*(port| |00005080| 2d 3e 76 69 73 52 67 6e | 29 29 2d 3e 72 67 6e 42 |->visRgn|))->rgnB| |00005090| 42 6f 78 3b 0d 09 53 63 | 61 6c 65 52 65 63 74 28 |Box;..Sc|aleRect(| |000050a0| 26 64 72 2c 20 26 70 6f | 72 74 72 2c 20 26 73 72 |&dr, &po|rtr, &sr| |000050b0| 2c 20 26 76 69 73 72 29 | 3b 0d 09 79 20 3d 20 76 |, &visr)|;..y = v| |000050c0| 69 73 72 2e 74 6f 70 3b | 0d 09 73 74 72 69 70 48 |isr.top;|..stripH| |000050d0| 65 69 67 68 74 20 3d 20 | 30 3b 0d 0d 09 66 6f 72 |eight = |0;...for| |000050e0| 28 20 3b 20 79 20 3c 20 | 76 69 73 72 2e 62 6f 74 |( ; y < |visr.bot| |000050f0| 74 6f 6d 20 26 26 20 79 | 20 3c 20 74 69 2d 3e 69 |tom && y| < ti->i| |00005100| 6d 61 67 65 4c 65 6e 67 | 74 68 3b 20 79 20 2b 3d |mageLeng|th; y +=| |00005110| 20 73 74 72 69 70 48 65 | 69 67 68 74 29 7b 0d 09 | stripHe|ight){..| |00005120| 09 70 20 3d 20 52 65 61 | 64 53 74 72 69 70 28 74 |.p = Rea|dStrip(t| |00005130| 69 2c 20 79 2c 20 26 79 | 2c 20 26 73 74 72 69 70 |i, y, &y|, &strip| |00005140| 48 65 69 67 68 74 29 3b | 0d 09 09 69 66 28 70 20 |Height);|...if(p | |00005150| 3d 3d 20 30 29 0d 09 09 | 09 67 6f 74 6f 20 62 61 |== 0)...|.goto ba| |00005160| 64 3b 0d 09 09 20 0d 09 | 09 2f 2a 0d 09 09 20 2a |d;... ..|./*... *| |00005170| 20 46 69 6e 64 20 61 20 | 77 61 79 20 74 6f 20 64 | Find a |way to d| |00005180| 72 61 77 20 74 68 65 20 | 73 74 72 69 70 2e 0d 09 |raw the |strip...| |00005190| 09 20 2a 2f 0d 09 09 69 | 66 28 74 69 2d 3e 73 61 |. */...i|f(ti->sa| |000051a0| 6d 70 6c 65 73 50 65 72 | 50 69 78 65 6c 20 3d 3d |mplesPer|Pixel ==| |000051b0| 20 31 20 26 26 0d 09 09 | 20 20 20 74 69 2d 3e 62 | 1 &&...| ti->b| |000051c0| 69 74 73 50 65 72 53 61 | 6d 70 6c 65 5b 30 5d 20 |itsPerSa|mple[0] | |000051d0| 3d 3d 20 31 20 26 26 0d | 09 09 20 20 20 28 74 69 |== 1 &&.|.. (ti| |000051e0| 2d 3e 70 68 6f 74 6f 6d | 65 74 72 69 63 49 6e 74 |->photom|etricInt| |000051f0| 65 72 70 72 65 74 61 74 | 69 6f 6e 20 3d 3d 20 50 |erpretat|ion == P| |00005200| 49 5a 65 72 6f 49 73 42 | 6c 61 63 6b 20 7c 7c 0d |IZeroIsB|lack ||.| |00005210| 09 09 20 20 20 20 74 69 | 2d 3e 70 68 6f 74 6f 6d |.. ti|->photom| |00005220| 65 74 72 69 63 49 6e 74 | 65 72 70 72 65 74 61 74 |etricInt|erpretat| |00005230| 69 6f 6e 20 3d 3d 20 50 | 49 5a 65 72 6f 49 73 57 |ion == P|IZeroIsW| |00005240| 68 69 74 65 29 29 7b 0d | 09 09 09 72 6f 77 62 79 |hite)){.|...rowby| |00005250| 74 65 73 20 3d 20 28 74 | 69 2d 3e 62 69 74 73 50 |tes = (t|i->bitsP| |00005260| 65 72 53 61 6d 70 6c 65 | 5b 30 5d 20 2a 20 74 69 |erSample|[0] * ti| |00005270| 2d 3e 69 6d 61 67 65 57 | 69 64 74 68 20 2b 20 37 |->imageW|idth + 7| |00005280| 29 20 2f 20 38 3b 0d 09 | 09 09 69 6e 76 20 3d 20 |) / 8;..|..inv = | |00005290| 74 69 2d 3e 70 68 6f 74 | 6f 6d 65 74 72 69 63 49 |ti->phot|ometricI| |000052a0| 6e 74 65 72 70 72 65 74 | 61 74 69 6f 6e 20 3d 3d |nterpret|ation ==| |000052b0| 20 50 49 5a 65 72 6f 49 | 73 42 6c 61 63 6b 3b 0d | PIZeroI|sBlack;.| |000052c0| 09 09 09 69 66 28 72 6f | 77 62 79 74 65 73 20 26 |...if(ro|wbytes &| |000052d0| 20 31 29 7b 0d 09 09 09 | 09 62 6d 2e 62 6f 75 6e | 1){....|.bm.boun| |000052e0| 64 73 2e 72 69 67 68 74 | 20 3d 20 74 69 2d 3e 69 |ds.right| = ti->i| |000052f0| 6d 61 67 65 57 69 64 74 | 68 3b 0d 09 09 09 09 62 |mageWidt|h;.....b| |00005300| 6d 2e 72 6f 77 42 79 74 | 65 73 20 3d 20 72 6f 77 |m.rowByt|es = row| |00005310| 62 79 74 65 73 20 2b 20 | 31 3b 0d 09 09 09 09 66 |bytes + |1;.....f| |00005320| 6f 72 28 69 20 3d 20 30 | 3b 20 69 20 3c 20 73 74 |or(i = 0|; i < st| |00005330| 72 69 70 48 65 69 67 68 | 74 3b 20 69 2b 2b 29 7b |ripHeigh|t; i++){| |00005340| 0d 09 09 09 09 09 70 31 | 20 3d 20 70 20 2b 20 28 |......p1| = p + (| |00005350| 69 20 2a 20 72 6f 77 62 | 79 74 65 73 29 3b 0d 09 |i * rowb|ytes);..| |00005360| 09 09 09 09 62 6d 2e 62 | 6f 75 6e 64 73 2e 74 6f |....bm.b|ounds.to| |00005370| 70 20 3d 20 79 20 2b 20 | 69 3b 0d 09 09 09 09 09 |p = y + |i;......| |00005380| 62 6d 2e 62 6f 75 6e 64 | 73 2e 62 6f 74 74 6f 6d |bm.bound|s.bottom| |00005390| 20 3d 20 79 20 2b 20 69 | 20 2b 20 31 3b 0d 09 09 | = y + i| + 1;...| |000053a0| 09 09 09 69 66 28 28 6c | 6f 6e 67 29 70 31 20 26 |...if((l|ong)p1 &| |000053b0| 20 31 29 7b 0d 09 09 09 | 09 09 09 62 6d 2e 62 6f | 1){....|...bm.bo| |000053c0| 75 6e 64 73 2e 6c 65 66 | 74 20 3d 20 2d 38 3b 0d |unds.lef|t = -8;.| |000053d0| 09 09 09 09 09 09 62 6d | 2e 62 61 73 65 41 64 64 |......bm|.baseAdd| |000053e0| 72 20 3d 20 70 31 20 2d | 20 31 3b 0d 09 09 09 09 |r = p1 -| 1;.....| |000053f0| 09 7d 20 65 6c 73 65 20 | 7b 0d 09 09 09 09 09 09 |.} else |{.......| |00005400| 62 6d 2e 62 6f 75 6e 64 | 73 2e 6c 65 66 74 20 3d |bm.bound|s.left =| |00005410| 20 30 3b 0d 09 09 09 09 | 09 09 62 6d 2e 62 61 73 | 0;.....|..bm.bas| |00005420| 65 41 64 64 72 20 3d 20 | 70 31 3b 0d 09 09 09 09 |eAddr = |p1;.....| |00005430| 09 7d 0d 09 09 09 09 09 | 43 6f 70 79 42 4d 53 74 |.}......|CopyBMSt| |00005440| 72 69 70 28 26 62 6d 2c | 20 73 72 2c 20 64 72 2c |rip(&bm,| sr, dr,| |00005450| 20 69 6e 76 29 3b 0d 09 | 09 09 09 7d 0d 09 09 09 | inv);..|...}....| |00005460| 7d 20 65 6c 73 65 20 7b | 0d 09 09 09 09 62 6d 2e |} else {|.....bm.| |00005470| 62 61 73 65 41 64 64 72 | 20 3d 20 70 3b 0d 09 09 |baseAddr| = p;...| |00005480| 09 09 62 6d 2e 72 6f 77 | 42 79 74 65 73 20 3d 20 |..bm.row|Bytes = | |00005490| 72 6f 77 62 79 74 65 73 | 3b 0d 09 09 09 09 62 6d |rowbytes|;.....bm| |000054a0| 2e 62 6f 75 6e 64 73 2e | 6c 65 66 74 20 3d 20 30 |.bounds.|left = 0| |000054b0| 3b 0d 09 09 09 09 62 6d | 2e 62 6f 75 6e 64 73 2e |;.....bm|.bounds.| |000054c0| 72 69 67 68 74 20 3d 20 | 74 69 2d 3e 69 6d 61 67 |right = |ti->imag| |000054d0| 65 57 69 64 74 68 3b 0d | 09 09 09 09 62 6d 2e 62 |eWidth;.|....bm.b| |000054e0| 6f 75 6e 64 73 2e 74 6f | 70 20 3d 20 79 3b 0d 09 |ounds.to|p = y;..| |000054f0| 09 09 09 62 6d 2e 62 6f | 75 6e 64 73 2e 62 6f 74 |...bm.bo|unds.bot| |00005500| 74 6f 6d 20 3d 20 79 20 | 2b 20 73 74 72 69 70 48 |tom = y |+ stripH| |00005510| 65 69 67 68 74 3b 0d 09 | 09 09 09 43 6f 70 79 42 |eight;..|...CopyB| |00005520| 4d 53 74 72 69 70 28 26 | 62 6d 2c 20 73 72 2c 20 |MStrip(&|bm, sr, | |00005530| 64 72 2c 20 69 6e 76 29 | 3b 0d 09 09 09 7d 09 09 |dr, inv)|;....}..| |00005540| 09 0d 09 09 7d 20 65 6c | 73 65 20 69 66 28 74 69 |....} el|se if(ti| |00005550| 2d 3e 73 61 6d 70 6c 65 | 73 50 65 72 50 69 78 65 |->sample|sPerPixe| |00005560| 6c 20 3d 3d 20 33 20 26 | 26 0d 09 09 20 20 20 74 |l == 3 &|&... t| |00005570| 69 2d 3e 62 69 74 73 50 | 65 72 53 61 6d 70 6c 65 |i->bitsP|erSample| |00005580| 5b 30 5d 20 3d 3d 20 38 | 20 26 26 0d 09 09 20 20 |[0] == 8| &&... | |00005590| 20 74 69 2d 3e 70 6c 61 | 6e 61 72 43 6f 6e 66 69 | ti->pla|narConfi| |000055a0| 67 75 72 61 74 69 6f 6e | 20 3d 3d 20 50 43 43 6f |guration| == PCCo| |000055b0| 6e 74 69 67 75 6f 75 73 | 20 26 26 0d 09 09 20 20 |ntiguous| &&... | |000055c0| 20 74 69 2d 3e 70 68 6f | 74 6f 6d 65 74 72 69 63 | ti->pho|tometric| |000055d0| 49 6e 74 65 72 70 72 65 | 74 61 74 69 6f 6e 20 3d |Interpre|tation =| |000055e0| 3d 20 50 49 52 47 42 29 | 7b 0d 09 09 09 2f 2a 20 |= PIRGB)|{..../* | |000055f0| 63 6f 6e 76 65 72 74 20 | 66 72 6f 6d 20 33 20 74 |convert |from 3 t| |00005600| 6f 20 34 20 62 79 74 65 | 73 20 70 65 72 20 70 69 |o 4 byte|s per pi| |00005610| 78 65 6c 20 2a 2f 0d 09 | 09 09 70 31 20 3d 20 54 |xel */..|..p1 = T| |00005620| 68 72 65 65 54 6f 46 6f | 75 72 28 70 2c 20 74 69 |hreeToFo|ur(p, ti| |00005630| 2d 3e 69 6d 61 67 65 57 | 69 64 74 68 20 2a 20 73 |->imageW|idth * s| |00005640| 74 72 69 70 48 65 69 67 | 68 74 29 3b 0d 09 09 09 |tripHeig|ht);....| |00005650| 69 66 28 70 31 20 3d 3d | 20 30 29 7b 0d 09 09 09 |if(p1 ==| 0){....| |00005660| 09 54 49 46 46 45 72 72 | 6f 72 28 74 69 2c 20 2d |.TIFFErr|or(ti, -| |00005670| 31 2c 20 22 5c 70 4f 75 | 74 20 6f 66 20 6d 65 6d |1, "\pOu|t of mem| |00005680| 6f 72 79 2e 22 29 3b 0d | 09 09 09 09 67 6f 74 6f |ory.");.|....goto| |00005690| 20 62 61 64 3b 0d 09 09 | 09 7d 0d 09 09 09 72 6f | bad;...|.}....ro| |000056a0| 77 62 79 74 65 73 20 3d | 20 34 20 2a 20 74 69 2d |wbytes =| 4 * ti-| |000056b0| 3e 69 6d 61 67 65 57 69 | 64 74 68 3b 0d 09 09 09 |>imageWi|dth;....| |000056c0| 70 6d 20 3d 20 52 47 42 | 50 69 78 4d 61 70 28 33 |pm = RGB|PixMap(3| |000056d0| 32 2c 20 30 2c 20 79 2c | 20 74 69 2d 3e 69 6d 61 |2, 0, y,| ti->ima| |000056e0| 67 65 57 69 64 74 68 2c | 20 73 74 72 69 70 48 65 |geWidth,| stripHe| |000056f0| 69 67 68 74 2c 20 70 31 | 2c 20 72 6f 77 62 79 74 |ight, p1|, rowbyt| |00005700| 65 73 29 3b 0d 09 09 09 | 69 66 28 70 6d 20 3d 3d |es);....|if(pm ==| |00005710| 20 30 29 7b 0d 09 09 09 | 09 44 69 73 70 6f 73 50 | 0){....|.DisposP| |00005720| 74 72 28 70 31 29 3b 0d | 09 09 09 09 54 49 46 46 |tr(p1);.|....TIFF| |00005730| 45 72 72 6f 72 28 74 69 | 2c 20 2d 31 2c 20 22 5c |Error(ti|, -1, "\| |00005740| 70 43 6f 75 6c 64 20 6e | 6f 74 20 61 6c 6c 6f 63 |pCould n|ot alloc| |00005750| 61 74 65 20 50 69 78 4d | 61 70 2e 22 29 3b 0d 09 |ate PixM|ap.");..| |00005760| 09 09 09 67 6f 74 6f 20 | 62 61 64 3b 0d 09 09 09 |...goto |bad;....| |00005770| 7d 0d 09 09 09 43 6f 70 | 79 50 4d 53 74 72 69 70 |}....Cop|yPMStrip| |00005780| 28 70 6d 2c 20 73 72 2c | 20 64 72 2c 20 64 69 74 |(pm, sr,| dr, dit| |00005790| 68 65 72 29 3b 0d 09 09 | 09 44 69 73 70 6f 73 50 |her);...|.DisposP| |000057a0| 69 78 4d 61 70 28 70 6d | 29 3b 0d 09 09 09 70 6d |ixMap(pm|);....pm| |000057b0| 20 3d 20 30 3b 0d 09 09 | 09 44 69 73 70 6f 73 50 | = 0;...|.DisposP| |000057c0| 74 72 28 70 31 29 3b 0d | 09 09 7d 20 65 6c 73 65 |tr(p1);.|..} else| |000057d0| 20 69 66 28 74 69 2d 3e | 73 61 6d 70 6c 65 73 50 | if(ti->|samplesP| |000057e0| 65 72 50 69 78 65 6c 20 | 3d 3d 20 31 20 26 26 0d |erPixel |== 1 &&.| |000057f0| 09 09 20 20 20 28 74 69 | 2d 3e 62 69 74 73 50 65 |.. (ti|->bitsPe| |00005800| 72 53 61 6d 70 6c 65 5b | 30 5d 20 3d 3d 20 31 20 |rSample[|0] == 1 | |00005810| 7c 7c 20 74 69 2d 3e 62 | 69 74 73 50 65 72 53 61 ||| ti->b|itsPerSa| |00005820| 6d 70 6c 65 5b 30 5d 20 | 3d 3d 20 32 20 7c 7c 0d |mple[0] |== 2 ||.| |00005830| 09 09 20 20 20 20 74 69 | 2d 3e 62 69 74 73 50 65 |.. ti|->bitsPe| |00005840| 72 53 61 6d 70 6c 65 5b | 30 5d 20 3d 3d 20 34 20 |rSample[|0] == 4 | |00005850| 7c 7c 20 74 69 2d 3e 62 | 69 74 73 50 65 72 53 61 ||| ti->b|itsPerSa| |00005860| 6d 70 6c 65 5b 30 5d 20 | 3d 3d 20 38 29 20 26 26 |mple[0] |== 8) &&| |00005870| 0d 09 09 20 20 20 28 74 | 69 2d 3e 70 68 6f 74 6f |... (t|i->photo| |00005880| 6d 65 74 72 69 63 49 6e | 74 65 72 70 72 65 74 61 |metricIn|terpreta| |00005890| 74 69 6f 6e 20 3d 3d 20 | 50 49 50 61 6c 65 74 74 |tion == |PIPalett| |000058a0| 65 20 7c 7c 0d 09 09 20 | 20 20 20 74 69 2d 3e 70 |e ||... | ti->p| |000058b0| 68 6f 74 6f 6d 65 74 72 | 69 63 49 6e 74 65 72 70 |hotometr|icInterp| |000058c0| 72 65 74 61 74 69 6f 6e | 20 3d 3d 20 50 49 5a 65 |retation| == PIZe| |000058d0| 72 6f 49 73 42 6c 61 63 | 6b 20 7c 7c 0d 09 09 20 |roIsBlac|k ||... | |000058e0| 20 20 20 74 69 2d 3e 70 | 68 6f 74 6f 6d 65 74 72 | ti->p|hotometr| |000058f0| 69 63 49 6e 74 65 72 70 | 72 65 74 61 74 69 6f 6e |icInterp|retation| |00005900| 20 3d 3d 20 50 49 5a 65 | 72 6f 49 73 57 68 69 74 | == PIZe|roIsWhit| |00005910| 65 29 29 7b 0d 09 09 09 | 72 6f 77 62 79 74 65 73 |e)){....|rowbytes| |00005920| 20 3d 20 28 74 69 2d 3e | 62 69 74 73 50 65 72 53 | = (ti->|bitsPerS| |00005930| 61 6d 70 6c 65 5b 30 5d | 20 2a 20 74 69 2d 3e 69 |ample[0]| * ti->i| |00005940| 6d 61 67 65 57 69 64 74 | 68 20 2b 20 37 29 20 2f |mageWidt|h + 7) /| |00005950| 20 38 3b 0d 09 09 09 69 | 66 28 72 6f 77 62 79 74 | 8;....i|f(rowbyt| |00005960| 65 73 20 26 20 31 29 7b | 0d 09 09 09 09 2f 2a 20 |es & 1){|...../* | |00005970| 6d 75 73 74 20 63 6f 70 | 79 20 6f 64 64 20 77 69 |must cop|y odd wi| |00005980| 64 74 68 73 20 61 20 6c | 69 6e 65 20 61 74 20 61 |dths a l|ine at a| |00005990| 20 74 69 6d 65 20 2a 2f | 0d 09 09 09 09 70 70 62 | time */|.....ppb| |000059a0| 20 3d 20 38 20 2f 20 74 | 69 2d 3e 62 69 74 73 50 | = 8 / t|i->bitsP| |000059b0| 65 72 53 61 6d 70 6c 65 | 5b 30 5d 3b 0d 09 09 09 |erSample|[0];....| |000059c0| 09 70 6d 20 3d 20 50 61 | 6c 65 74 74 65 50 69 78 |.pm = Pa|lettePix| |000059d0| 4d 61 70 28 74 69 2d 3e | 62 69 74 73 50 65 72 53 |Map(ti->|bitsPerS| |000059e0| 61 6d 70 6c 65 5b 30 5d | 2c 20 74 69 2d 3e 63 6f |ample[0]|, ti->co| |000059f0| 6c 6f 72 4d 61 70 2c 0d | 09 09 09 09 09 09 09 09 |lorMap,.|........| |00005a00| 20 20 20 30 2c 20 30 2c | 0d 09 09 09 09 09 09 09 | 0, 0,|........| |00005a10| 09 20 20 20 74 69 2d 3e | 69 6d 61 67 65 57 69 64 |. ti->|imageWid| |00005a20| 74 68 2c 20 31 2c 0d 09 | 09 09 09 09 09 09 09 20 |th, 1,..|....... | |00005a30| 20 20 30 2c 20 72 6f 77 | 62 79 74 65 73 20 2b 20 | 0, row|bytes + | |00005a40| 31 29 3b 0d 09 09 09 09 | 69 66 28 70 6d 20 3d 3d |1);.....|if(pm ==| |00005a50| 20 30 29 7b 0d 09 09 09 | 09 09 54 49 46 46 45 72 | 0){....|..TIFFEr| |00005a60| 72 6f 72 28 74 69 2c 20 | 2d 31 2c 20 22 5c 70 43 |ror(ti, |-1, "\pC| |00005a70| 6f 75 6c 64 20 6e 6f 74 | 20 61 6c 6c 6f 63 61 74 |ould not| allocat| |00005a80| 65 20 50 69 78 4d 61 70 | 2e 22 29 3b 0d 09 09 09 |e PixMap|.");....| |00005a90| 09 09 67 6f 74 6f 20 62 | 61 64 3b 0d 09 09 09 09 |..goto b|ad;.....| |00005aa0| 7d 0d 09 09 09 09 66 6f | 72 28 69 20 3d 20 30 3b |}.....fo|r(i = 0;| |00005ab0| 20 69 20 3c 20 73 74 72 | 69 70 48 65 69 67 68 74 | i < str|ipHeight| |00005ac0| 3b 20 69 2b 2b 29 7b 0d | 09 09 09 09 09 70 31 20 |; i++){.|.....p1 | |00005ad0| 3d 20 70 20 2b 20 28 69 | 20 2a 20 72 6f 77 62 79 |= p + (i| * rowby| |00005ae0| 74 65 73 29 3b 0d 09 09 | 09 09 09 28 2a 70 6d 29 |tes);...|...(*pm)| |00005af0| 2d 3e 62 6f 75 6e 64 73 | 2e 74 6f 70 20 3d 20 79 |->bounds|.top = y| |00005b00| 20 2b 20 69 3b 0d 09 09 | 09 09 09 28 2a 70 6d 29 | + i;...|...(*pm)| |00005b10| 2d 3e 62 6f 75 6e 64 73 | 2e 62 6f 74 74 6f 6d 20 |->bounds|.bottom | |00005b20| 3d 20 79 20 2b 20 69 20 | 2b 20 31 3b 0d 09 09 09 |= y + i |+ 1;....| |00005b30| 09 09 69 66 28 28 6c 6f | 6e 67 29 70 31 20 26 20 |..if((lo|ng)p1 & | |00005b40| 31 29 7b 0d 09 09 09 09 | 09 09 28 2a 70 6d 29 2d |1){.....|..(*pm)-| |00005b50| 3e 62 6f 75 6e 64 73 2e | 6c 65 66 74 20 3d 20 2d |>bounds.|left = -| |00005b60| 70 70 62 3b 0d 09 09 09 | 09 09 09 28 2a 70 6d 29 |ppb;....|...(*pm)| |00005b70| 2d 3e 62 61 73 65 41 64 | 64 72 20 3d 20 70 31 20 |->baseAd|dr = p1 | |00005b80| 2d 20 31 3b 0d 09 09 09 | 09 09 7d 20 65 6c 73 65 |- 1;....|..} else| |00005b90| 20 7b 0d 09 09 09 09 09 | 09 28 2a 70 6d 29 2d 3e | {......|.(*pm)->| |00005ba0| 62 6f 75 6e 64 73 2e 6c | 65 66 74 20 3d 20 30 3b |bounds.l|eft = 0;| |00005bb0| 0d 09 09 09 09 09 09 28 | 2a 70 6d 29 2d 3e 62 61 |.......(|*pm)->ba| |00005bc0| 73 65 41 64 64 72 20 3d | 20 70 31 3b 0d 09 09 09 |seAddr =| p1;....| |00005bd0| 09 09 7d 0d 09 09 09 09 | 09 43 6f 70 79 50 4d 53 |..}.....|.CopyPMS| |00005be0| 74 72 69 70 28 70 6d 2c | 20 73 72 2c 20 64 72 2c |trip(pm,| sr, dr,| |00005bf0| 20 64 69 74 68 65 72 29 | 3b 0d 09 09 09 09 7d 0d | dither)|;.....}.| |00005c00| 09 09 09 09 44 69 73 70 | 6f 73 50 69 78 4d 61 70 |....Disp|osPixMap| |00005c10| 28 70 6d 29 3b 0d 09 09 | 09 09 70 6d 20 3d 20 30 |(pm);...|..pm = 0| |00005c20| 3b 0d 09 09 09 7d 20 65 | 6c 73 65 20 7b 0d 09 09 |;....} e|lse {...| |00005c30| 09 09 70 6d 20 3d 20 50 | 61 6c 65 74 74 65 50 69 |..pm = P|alettePi| |00005c40| 78 4d 61 70 28 74 69 2d | 3e 62 69 74 73 50 65 72 |xMap(ti-|>bitsPer| |00005c50| 53 61 6d 70 6c 65 5b 30 | 5d 2c 20 74 69 2d 3e 63 |Sample[0|], ti->c| |00005c60| 6f 6c 6f 72 4d 61 70 2c | 0d 09 09 09 09 09 09 09 |olorMap,|........| |00005c70| 09 20 20 20 30 2c 20 79 | 2c 0d 09 09 09 09 09 09 |. 0, y|,.......| |00005c80| 09 09 20 20 20 74 69 2d | 3e 69 6d 61 67 65 57 69 |.. ti-|>imageWi| |00005c90| 64 74 68 2c 20 73 74 72 | 69 70 48 65 69 67 68 74 |dth, str|ipHeight| |00005ca0| 2c 0d 09 09 09 09 09 09 | 09 09 20 20 20 70 2c 20 |,.......|.. p, | |00005cb0| 72 6f 77 62 79 74 65 73 | 29 3b 0d 09 09 09 09 69 |rowbytes|);.....i| |00005cc0| 66 28 70 6d 20 3d 3d 20 | 30 29 7b 0d 09 09 09 09 |f(pm == |0){.....| |00005cd0| 09 54 49 46 46 45 72 72 | 6f 72 28 74 69 2c 20 2d |.TIFFErr|or(ti, -| |00005ce0| 31 2c 20 22 5c 70 43 6f | 75 6c 64 20 6e 6f 74 20 |1, "\pCo|uld not | |00005cf0| 61 6c 6c 6f 63 61 74 65 | 20 50 69 78 4d 61 70 2e |allocate| PixMap.| |00005d00| 22 29 3b 0d 09 09 09 09 | 09 67 6f 74 6f 20 62 61 |");.....|.goto ba| |00005d10| 64 3b 0d 09 09 09 09 7d | 0d 09 09 09 09 43 6f 70 |d;.....}|.....Cop| |00005d20| 79 50 4d 53 74 72 69 70 | 28 70 6d 2c 20 73 72 2c |yPMStrip|(pm, sr,| |00005d30| 20 64 72 2c 20 64 69 74 | 68 65 72 29 3b 0d 09 09 | dr, dit|her);...| |00005d40| 09 09 44 69 73 70 6f 73 | 50 69 78 4d 61 70 28 70 |..Dispos|PixMap(p| |00005d50| 6d 29 3b 0d 09 09 09 09 | 70 6d 20 3d 20 30 3b 0d |m);.....|pm = 0;.| |00005d60| 09 09 09 7d 0d 09 09 7d | 20 65 6c 73 65 20 7b 0d |...}...}| else {.| |00005d70| 09 09 09 54 49 46 46 45 | 72 72 6f 72 28 74 69 2c |...TIFFE|rror(ti,| |00005d80| 20 2d 31 2c 20 22 5c 70 | 55 6e 69 6d 70 6c 65 6d | -1, "\p|Unimplem| |00005d90| 65 6e 74 65 64 20 69 6d | 61 67 65 20 72 65 70 72 |ented im|age repr| |00005da0| 65 73 65 6e 74 61 74 69 | 6f 6e 2e 22 29 3b 0d 09 |esentati|on.");..| |00005db0| 09 09 67 6f 74 6f 20 62 | 61 64 3b 0d 09 09 7d 09 |..goto b|ad;...}.| |00005dc0| 09 0d 09 09 09 0d 09 09 | 44 69 73 70 6f 73 50 74 |........|DisposPt| |00005dd0| 72 28 70 29 3b 0d 09 09 | 70 20 3d 20 30 3b 0d 09 |r(p);...|p = 0;..| |00005de0| 7d 0d 09 0d 09 72 65 74 | 75 72 6e 28 30 29 3b 0d |}....ret|urn(0);.| |00005df0| 09 0d 62 61 64 3a 0d 09 | 69 66 28 70 29 0d 09 09 |..bad:..|if(p)...| |00005e00| 44 69 73 70 6f 73 50 74 | 72 28 70 29 3b 0d 09 69 |DisposPt|r(p);..i| |00005e10| 66 28 70 6d 29 0d 09 09 | 44 69 73 70 6f 73 50 69 |f(pm)...|DisposPi| |00005e20| 78 4d 61 70 28 70 6d 29 | 3b 0d 09 72 65 74 75 72 |xMap(pm)|;..retur| |00005e30| 6e 28 2d 31 29 3b 0d 7d | 0d 0d 2f 2a 0d 20 2a 20 |n(-1);.}|../*. * | |00005e40| 43 6f 70 79 20 61 20 70 | 69 78 6d 61 70 20 6f 66 |Copy a p|ixmap of| |00005e50| 20 61 20 73 74 72 69 70 | 20 74 6f 20 74 68 65 20 | a strip| to the | |00005e60| 72 69 67 68 74 20 70 6c | 61 63 65 2e 0d 20 2a 2f |right pl|ace.. */| |00005e70| 0d 76 6f 69 64 0d 43 6f | 70 79 50 4d 53 74 72 69 |.void.Co|pyPMStri| |00005e80| 70 28 50 69 78 4d 61 70 | 48 61 6e 64 6c 65 20 70 |p(PixMap|Handle p| |00005e90| 6d 2c 20 52 65 63 74 20 | 73 72 2c 20 52 65 63 74 |m, Rect |sr, Rect| |00005ea0| 20 64 72 2c 20 69 6e 74 | 20 64 69 74 68 65 72 29 | dr, int| dither)| |00005eb0| 0d 7b 0d 09 52 65 63 74 | 20 73 72 31 2c 20 64 72 |.{..Rect| sr1, dr| |00005ec0| 31 3b 0d 09 47 72 61 66 | 50 74 72 20 70 6f 72 74 |1;..Graf|Ptr port| |00005ed0| 3b 0d 0d 09 73 72 31 20 | 3d 20 28 2a 70 6d 29 2d |;...sr1 |= (*pm)-| |00005ee0| 3e 62 6f 75 6e 64 73 3b | 0d 09 73 72 31 2e 6c 65 |>bounds;|..sr1.le| |00005ef0| 66 74 20 3d 20 73 72 2e | 6c 65 66 74 3b 0d 09 73 |ft = sr.|left;..s| |00005f00| 72 31 2e 72 69 67 68 74 | 20 3d 20 73 72 2e 72 69 |r1.right| = sr.ri| |00005f10| 67 68 74 3b 0d 09 69 66 | 28 73 72 31 2e 74 6f 70 |ght;..if|(sr1.top| |00005f20| 20 3c 20 73 72 2e 74 6f | 70 29 0d 09 09 73 72 31 | < sr.to|p)...sr1| |00005f30| 2e 74 6f 70 20 3d 20 73 | 72 2e 74 6f 70 3b 0d 09 |.top = s|r.top;..| |00005f40| 69 66 28 73 72 31 2e 62 | 6f 74 74 6f 6d 20 3e 20 |if(sr1.b|ottom > | |00005f50| 73 72 2e 62 6f 74 74 6f | 6d 29 0d 09 09 73 72 31 |sr.botto|m)...sr1| |00005f60| 2e 62 6f 74 74 6f 6d 20 | 3d 20 73 72 2e 62 6f 74 |.bottom |= sr.bot| |00005f70| 74 6f 6d 3b 0d 09 09 0d | 09 53 63 61 6c 65 52 65 |tom;....|.ScaleRe| |00005f80| 63 74 28 26 73 72 2c 20 | 26 73 72 31 2c 20 26 64 |ct(&sr, |&sr1, &d| |00005f90| 72 2c 20 26 64 72 31 29 | 3b 0d 09 0d 09 47 65 74 |r, &dr1)|;....Get| |00005fa0| 50 6f 72 74 28 26 70 6f | 72 74 29 3b 0d 09 0d 09 |Port(&po|rt);....| |00005fb0| 4d 6f 76 65 48 48 69 28 | 70 6d 29 3b 0d 09 48 4c |MoveHHi(|pm);..HL| |00005fc0| 6f 63 6b 28 70 6d 29 3b | 0d 09 43 6f 70 79 42 69 |ock(pm);|..CopyBi| |00005fd0| 74 73 28 2a 70 6d 2c 20 | 26 28 70 6f 72 74 2d 3e |ts(*pm, |&(port->| |00005fe0| 70 6f 72 74 42 69 74 73 | 29 2c 20 26 73 72 31 2c |portBits|), &sr1,| |00005ff0| 20 26 64 72 31 2c 20 64 | 69 74 68 65 72 20 3f 20 | &dr1, d|ither ? | |00006000| 36 34 20 3a 20 73 72 63 | 43 6f 70 79 2c 20 30 4c |64 : src|Copy, 0L| |00006010| 29 3b 0d 09 48 55 6e 6c | 6f 63 6b 28 70 6d 29 3b |);..HUnl|ock(pm);| |00006020| 0d 7d 0d 0d 2f 2a 0d 20 | 2a 20 43 6f 70 79 20 61 |.}../*. |* Copy a| |00006030| 20 62 69 74 6d 61 70 20 | 6f 66 20 61 20 73 74 72 | bitmap |of a str| |00006040| 69 70 20 74 6f 20 74 68 | 65 20 72 69 67 68 74 20 |ip to th|e right | |00006050| 70 6c 61 63 65 2e 0d 20 | 2a 20 4f 70 74 69 6f 6e |place.. |* Option| |00006060| 61 6c 6c 79 20 69 6e 76 | 65 72 74 20 62 6c 61 63 |ally inv|ert blac| |00006070| 6b 20 61 6e 64 20 77 68 | 69 74 65 2e 0d 20 2a 2f |k and wh|ite.. */| |00006080| 0d 76 6f 69 64 0d 43 6f | 70 79 42 4d 53 74 72 69 |.void.Co|pyBMStri| |00006090| 70 28 42 69 74 4d 61 70 | 20 2a 62 6d 2c 20 52 65 |p(BitMap| *bm, Re| |000060a0| 63 74 20 73 72 2c 20 52 | 65 63 74 20 64 72 2c 20 |ct sr, R|ect dr, | |000060b0| 69 6e 74 20 69 6e 76 29 | 0d 7b 0d 09 52 65 63 74 |int inv)|.{..Rect| |000060c0| 20 73 72 31 2c 20 64 72 | 31 3b 0d 09 47 72 61 66 | sr1, dr|1;..Graf| |000060d0| 50 74 72 20 70 6f 72 74 | 3b 0d 0d 09 73 72 31 20 |Ptr port|;...sr1 | |000060e0| 3d 20 62 6d 2d 3e 62 6f | 75 6e 64 73 3b 0d 09 73 |= bm->bo|unds;..s| |000060f0| 72 31 2e 6c 65 66 74 20 | 3d 20 73 72 2e 6c 65 66 |r1.left |= sr.lef| |00006100| 74 3b 0d 09 73 72 31 2e | 72 69 67 68 74 20 3d 20 |t;..sr1.|right = | |00006110| 73 72 2e 72 69 67 68 74 | 3b 0d 09 69 66 28 73 72 |sr.right|;..if(sr| |00006120| 31 2e 74 6f 70 20 3c 20 | 73 72 2e 74 6f 70 29 0d |1.top < |sr.top).| |00006130| 09 09 73 72 31 2e 74 6f | 70 20 3d 20 73 72 2e 74 |..sr1.to|p = sr.t| |00006140| 6f 70 3b 0d 09 69 66 28 | 73 72 31 2e 62 6f 74 74 |op;..if(|sr1.bott| |00006150| 6f 6d 20 3e 20 73 72 2e | 62 6f 74 74 6f 6d 29 0d |om > sr.|bottom).| |00006160| 09 09 73 72 31 2e 62 6f | 74 74 6f 6d 20 3d 20 73 |..sr1.bo|ttom = s| |00006170| 72 2e 62 6f 74 74 6f 6d | 3b 0d 09 09 0d 09 53 63 |r.bottom|;.....Sc| |00006180| 61 6c 65 52 65 63 74 28 | 26 73 72 2c 20 26 73 72 |aleRect(|&sr, &sr| |00006190| 31 2c 20 26 64 72 2c 20 | 26 64 72 31 29 3b 0d 09 |1, &dr, |&dr1);..| |000061a0| 0d 09 47 65 74 50 6f 72 | 74 28 26 70 6f 72 74 29 |..GetPor|t(&port)| |000061b0| 3b 0d 09 0d 09 43 6f 70 | 79 42 69 74 73 28 62 6d |;....Cop|yBits(bm| |000061c0| 2c 20 26 28 70 6f 72 74 | 2d 3e 70 6f 72 74 42 69 |, &(port|->portBi| |000061d0| 74 73 29 2c 20 26 73 72 | 31 2c 20 26 64 72 31 2c |ts), &sr|1, &dr1,| |000061e0| 20 69 6e 76 20 3f 20 6e | 6f 74 53 72 63 43 6f 70 | inv ? n|otSrcCop| |000061f0| 79 20 3a 20 73 72 63 43 | 6f 70 79 2c 20 30 4c 29 |y : srcC|opy, 0L)| |00006200| 3b 0d 7d 0d 0d 0d 2f 2a | 0d 20 2a 20 43 6f 6e 76 |;.}.../*|. * Conv| |00006210| 65 72 74 20 33 2d 62 79 | 74 65 73 2d 70 65 72 2d |ert 3-by|tes-per-| |00006220| 70 69 78 65 6c 20 52 47 | 42 20 64 61 74 61 20 74 |pixel RG|B data t| |00006230| 6f 20 34 2d 62 79 74 65 | 73 2d 70 65 72 2d 70 69 |o 4-byte|s-per-pi| |00006240| 78 65 6c 2c 20 61 73 20 | 72 65 71 75 69 72 65 64 |xel, as |required| |00006250| 0d 20 2a 20 66 6f 72 20 | 51 75 69 63 6b 44 72 61 |. * for |QuickDra| |00006260| 77 20 33 32 2d 62 69 74 | 20 50 69 78 20 4d 61 70 |w 32-bit| Pix Map| |00006270| 73 2e 20 69 6e 4c 65 6e | 20 69 73 20 74 68 65 20 |s. inLen| is the | |00006280| 6e 75 6d 62 65 72 20 6f | 66 20 62 79 74 65 73 2e |number o|f bytes.| |00006290| 0d 20 2a 2f 0d 50 74 72 | 0d 54 68 72 65 65 54 6f |. */.Ptr|.ThreeTo| |000062a0| 46 6f 75 72 28 50 74 72 | 20 69 6e 2c 20 6c 6f 6e |Four(Ptr| in, lon| |000062b0| 67 20 6e 50 69 78 65 6c | 73 29 0d 7b 0d 09 50 74 |g nPixel|s).{..Pt| |000062c0| 72 20 6f 75 74 3b 0d 09 | 72 65 67 69 73 74 65 72 |r out;..|register| |000062d0| 20 75 6e 73 69 67 6e 65 | 64 20 6c 6f 6e 67 20 2a | unsigne|d long *| |000062e0| 69 6e 70 2c 20 2a 6f 75 | 74 70 3b 0d 09 72 65 67 |inp, *ou|tp;..reg| |000062f0| 69 73 74 65 72 20 75 6e | 73 69 67 6e 65 64 20 6c |ister un|signed l| |00006300| 6f 6e 67 20 69 6e 31 2c | 20 69 6e 32 2c 20 69 6e |ong in1,| in2, in| |00006310| 33 3b 0d 09 63 68 61 72 | 20 2a 69 70 2c 20 2a 6f |3;..char| *ip, *o| |00006320| 70 3b 0d 09 0d 09 6f 75 | 74 20 3d 20 4e 65 77 50 |p;....ou|t = NewP| |00006330| 74 72 28 34 20 2a 20 6e | 50 69 78 65 6c 73 29 3b |tr(4 * n|Pixels);| |00006340| 0d 09 69 66 28 6f 75 74 | 20 3d 3d 20 30 29 0d 09 |..if(out| == 0)..| |00006350| 09 72 65 74 75 72 6e 28 | 30 29 3b 0d 09 09 0d 09 |.return(|0);.....| |00006360| 69 6e 70 20 3d 20 28 75 | 6e 73 69 67 6e 65 64 20 |inp = (u|nsigned | |00006370| 6c 6f 6e 67 20 2a 29 20 | 69 6e 3b 0d 09 6f 75 74 |long *) |in;..out| |00006380| 70 20 3d 20 28 75 6e 73 | 69 67 6e 65 64 20 6c 6f |p = (uns|igned lo| |00006390| 6e 67 20 2a 29 20 6f 75 | 74 3b 0d 09 0d 09 66 6f |ng *) ou|t;....fo| |000063a0| 72 28 20 3b 20 6e 50 69 | 78 65 6c 73 20 3e 3d 20 |r( ; nPi|xels >= | |000063b0| 34 3b 20 6e 50 69 78 65 | 6c 73 20 2d 3d 20 34 29 |4; nPixe|ls -= 4)| |000063c0| 7b 0d 09 09 2f 2a 20 72 | 65 61 64 20 34 20 70 69 |{.../* r|ead 4 pi| |000063d0| 78 65 6c 73 20 77 6f 72 | 74 68 20 6f 66 20 64 61 |xels wor|th of da| |000063e0| 74 61 20 69 6e 20 34 20 | 6c 6f 6e 67 73 3a 20 52 |ta in 4 |longs: R| |000063f0| 47 42 52 20 47 42 52 47 | 20 42 52 47 42 20 2a 2f |GBR GBRG| BRGB */| +--------+-------------------------+-------------------------+--------+--------+ Only 25.0 KB of data is shown above.